source: mod_gnutls/configure.ac @ ded2291

asynciodebian/mastermainproxy-ticket
Last change on this file since ded2291 was 6bbd378, checked in by Fiona Klute <fiona.klute@…>, 5 years ago

Remove special handling for APR memcache and leftover includes

  • Property mode set to 100644
File size: 10.4 KB
Line 
1AC_INIT(mod_gnutls, 0.8.4)
2OOO_CONFIG_NICE(config.nice)
3MOD_GNUTLS_VERSION=AC_PACKAGE_VERSION
4AC_PREREQ(2.53)
5AC_CONFIG_SRCDIR([src/mod_gnutls.c])
6AC_CONFIG_AUX_DIR(config)
7
8OOO_MAINTAIN_MODE
9AM_MAINTAINER_MODE
10AC_CANONICAL_TARGET
11# mod_gnutls test suite requires GNU make
12AM_INIT_AUTOMAKE([-Wno-portability])
13AM_CONFIG_HEADER(include/mod_gnutls_config.h:config.in)
14
15LT_INIT([disable-static])
16
17AC_SUBST(MOD_GNUTLS_VERSION)
18
19AC_PROG_CC
20AC_PROG_CC_C99
21AC_PROG_LD
22AC_PROG_INSTALL
23AC_PROG_LIBTOOL
24
25AC_CONFIG_MACRO_DIR([m4])
26
27AP_VERSION=2.4.17
28CHECK_APACHE(,$AP_VERSION,
29    :,:,
30    AC_MSG_ERROR([*** Apache version $AP_VERSION not found!])
31)
32
33PKG_CHECK_MODULES([LIBGNUTLS], [gnutls >= 3.3.0])
34
35LIBGNUTLS_VERSION=`pkg-config --modversion gnutls`
36
37AC_ARG_ENABLE(vpath-install,
38       AS_HELP_STRING([--enable-vpath-install],
39               [Modify the Apache module directory provided by apxs to \
40               follow --prefix, if necessary. Most users will not want this, \
41               but it is required for VPATH builds including "make \
42               distcheck".]),
43       vpath_install=$enableval, vpath_install=no)
44AM_CONDITIONAL([ENABLE_VPATH_INSTALL], [test "$vpath_install" = "yes"])
45
46AC_ARG_ENABLE(srp,
47       AS_HELP_STRING([--disable-srp],
48               [unconditionally disable the SRP functionality]),
49       use_srp=$enableval, use_srp=yes)
50
51# check if the available GnuTLS library supports SRP
52AC_SEARCH_LIBS([gnutls_srp_server_get_username], [gnutls], [], [use_srp="no"])
53
54SRP_CFLAGS=""
55if test "$use_srp" != "no"; then
56        SRP_CFLAGS="-DENABLE_SRP=1"
57fi
58
59AC_ARG_ENABLE(strict,
60       AS_HELP_STRING([--disable-strict],
61               [Avoid strict compiler warnings and errors]),
62       use_strict=$enableval, use_strict=yes)
63
64STRICT_CFLAGS=""
65if test "$use_strict" != "no"; then
66        STRICT_CFLAGS="-Wall -Werror -Wextra -Wno-error=deprecated-declarations"
67fi
68
69AC_MSG_CHECKING([whether to enable SRP functionality])
70AC_MSG_RESULT($use_srp)
71
72dnl Optionally disable flock
73AC_ARG_ENABLE(flock,
74        AS_HELP_STRING([--disable-flock], [Disable use of flock during tests \
75        (some exotic architectures don't support it)]),
76        [use_flock=$enableval], [use_flock=yes])
77# Check if flock is available and supports --timeout
78AC_PATH_PROG([FLOCK], [flock], [no])
79AS_IF([test "${FLOCK}" != "no"],
80      [
81        AC_MSG_CHECKING([whether ${FLOCK} supports --timeout])
82        lockfile="$(mktemp)"
83        AS_IF([${FLOCK} --timeout 1 ${lockfile} true >&AS_MESSAGE_LOG_FD 2>&1],
84              [flock_works="yes"], [flock_works="no"])
85        AC_MSG_RESULT([$flock_works])
86        # Old versions of flock do not support --verbose. They fail
87        # without executing the command but still return 0. Check for
88        # this behavior by testing if the rm command was executed.
89        AC_MSG_CHECKING([whether ${FLOCK} supports --verbose])
90        testfile="$(mktemp)"
91        AS_IF([${FLOCK} --verbose --timeout 1 ${lockfile} rm "${testfile}" \
92                        >&AS_MESSAGE_LOG_FD 2>&1; test ! -e "${testfile}"],
93              [flock_verbose="yes"; FLOCK="${FLOCK} --verbose"],
94              [flock_verbose="no"; rm "${testfile}"])
95        AC_MSG_RESULT([$flock_verbose])
96        rm "${lockfile}"
97      ],
98      [flock_works="no"])
99# disable flock if requested by user or it doesn't support timeout
100AM_CONDITIONAL([DISABLE_FLOCK],
101               [test "$enable_flock" = "no" || test "$flock_works" = "no"])
102
103# openssl is needed as the responder for OCSP tests
104AC_PATH_PROG([OPENSSL], [openssl], [no])
105# OCSP checks with gnutls-cli from GnuTLS versions before 3.3.23,
106# 3.4.12, or 3.5.1 (on the respective 3.x branch) fail if intermediate
107# CAs cannot be status checked, even if there are no intermediate CAs
108# like in the mod_gnutls test suite where end entity certificates are
109# directly issued by a root CA.
110AC_MSG_CHECKING([for gnutls-cli version supporting OCSP for EE under root CA])
111AC_PREPROC_IFELSE(
112        [AC_LANG_SOURCE([[#include "gnutls/gnutls.h"
113                        #if GNUTLS_VERSION_NUMBER < 0x030317
114                        #error
115                        #elif GNUTLS_VERSION_NUMBER >= 0x030400 && GNUTLS_VERSION_NUMBER < 0x03040c
116                        #error
117                        #elif GNUTLS_VERSION_NUMBER == 0x030500
118                        #error
119                        #endif
120                        ]])],
121        [gnutls_ocsp_ok="yes"],
122        [gnutls_ocsp_ok="no"],
123)
124AC_MSG_RESULT([$gnutls_ocsp_ok])
125AM_CONDITIONAL([ENABLE_OCSP_TEST], [test "${OPENSSL}" != "no" && test "${gnutls_ocsp_ok}" = "yes"])
126
127dnl Enable test namespaces? Default is "yes".
128AC_ARG_ENABLE(test-namespaces,
129        AS_HELP_STRING([--disable-test-namespaces], [Disable use of network \
130        namespaces to run tests in parallel (some architectures might not \
131        support it)]),
132        [use_netns=$enableval], [use_netns=yes])
133
134# Check if "unshare" is available and has permission to create network
135# and user namespaces
136AC_PATH_PROG([UNSHARE], [unshare], [no])
137AS_IF([test "${UNSHARE}" != "no"],
138      [
139        AC_MSG_CHECKING([for permission to create network and user namespaces])
140        AS_IF([${UNSHARE} --net -r /bin/sh -c \
141                "ip link set up lo && ip addr show" >&AS_MESSAGE_LOG_FD 2>&1],
142              [unshare_works="yes"], [unshare_works="no"])
143        AC_MSG_RESULT([$unshare_works])
144      ],
145      [unshare_works="no"])
146# decide whether to enable network namespaces
147AS_IF([test "$enable_test_namespaces" != "no" \
148            && test "$unshare_works" = "yes"],
149      [use_netns="yes"], [use_netns="no"])
150AM_CONDITIONAL([ENABLE_NETNS], [test "$use_netns" != "no"])
151# Adjust Apache configuration for tests accordingly: Use pthread mutex
152# and test specific PID files if using namespaces, defaults otherwise.
153AS_IF([test "$use_netns" = "yes"],
154      [MUTEX_CONF="Mutex pthread default"; PID_AFFIX="-\${TEST_NAME}"],
155      [MUTEX_CONF=""; PID_AFFIX=""])
156AC_SUBST(MUTEX_CONF)
157AC_SUBST(PID_AFFIX)
158AM_SUBST_NOTMAKE(MUTEX_CONF)
159AM_SUBST_NOTMAKE(PID_AFFIX)
160
161AC_ARG_ENABLE(msva,
162       AS_HELP_STRING([--enable-msva],
163               [enable Monkeysphere client certificate verification]),
164       use_msva=$enableval, use_msva=no)
165AM_CONDITIONAL([USE_MSVA], [test "$use_msva" != "no"])
166
167MSVA_CFLAGS=""
168if test "$use_msva" != "no"; then
169        AC_CHECK_HEADERS([msv/msv.h], [],
170                         [AC_MSG_ERROR([*** No libmsv headers found!])])
171        AC_SEARCH_LIBS([msv_query_agent], [msv], [],
172                         [AC_MSG_ERROR([*** No libmsv found with msv_query_agent!])])
173        MSVA_CFLAGS="-DENABLE_MSVA=1"
174fi
175
176AC_MSG_CHECKING([whether to enable MSVA functionality])
177AC_MSG_RESULT($use_msva)
178
179# Building documentation requires pandoc, which in turn needs pdflatex
180# to build PDF output.
181build_doc=no
182AC_PATH_PROG([PANDOC], [pandoc], [no])
183if test "$PANDOC" != "no"; then
184        AC_PATH_PROG([PDFLATEX], [pdflatex], [no])
185        if test "$PDFLATEX" != "no"; then
186                build_doc=yes
187        else
188                build_doc="html only"
189        fi
190else
191        AC_PATH_PROG([MARKDOWN], [markdown], [no])
192        if test "$MARKDOWN" != "no"; then
193                build_doc="html stub"
194        fi
195fi
196AM_CONDITIONAL([USE_PANDOC], [test "$PANDOC" != "no"])
197AM_CONDITIONAL([USE_PDFLATEX], [test "$PANDOC" != "no" && \
198                               test "$PDFLATEX" != "no"])
199AM_CONDITIONAL([USE_MARKDOWN], [test -n "$MARKDOWN" && \
200                               test "$MARKDOWN" != "no"])
201
202# Check for Apache binary
203AC_PATH_PROGS([APACHE2], [apache2 httpd], [no], [$PATH:/usr/sbin])
204if test "${APACHE2}" = "no"; then
205        AC_MSG_WARN([Neither apache2 nor httpd found in \
206                     PATH. Test suite will fail.])
207fi
208
209AC_PATH_PROGS([HTTP_CLI], [curl wget], [no])
210
211MODULE_CFLAGS="${LIBGNUTLS_CFLAGS} ${SRP_CFLAGS} ${MSVA_CFLAGS} ${APXS_CFLAGS} ${AP_INCLUDES} ${APR_INCLUDES} ${APU_INCLUDES} ${STRICT_CFLAGS}"
212MODULE_LIBS="${LIBGNUTLS_LIBS}"
213
214AC_PATH_PROGS([SOFTHSM], [softhsm2-util softhsm], [no])
215if test "${SOFTHSM}" != "no"; then
216        softhsm_version=$(${SOFTHSM} --version)
217        AS_VERSION_COMPARE([$(${SOFTHSM} --version)], [2.0.0],
218                           [AC_SUBST(SOFTHSM_MAJOR_VERSION, [1])],
219                           [AC_SUBST(SOFTHSM_MAJOR_VERSION, [2])],
220                           [AC_SUBST(SOFTHSM_MAJOR_VERSION, [2])])
221fi
222AM_CONDITIONAL([HAVE_SOFTHSM], [test "${SOFTHSM}" != "no"])
223AM_CONDITIONAL([HAVE_SOFTHSM1], [test "${SOFTHSM_MAJOR_VERSION}" = "1"])
224AM_CONDITIONAL([HAVE_SOFTHSM2], [test "${SOFTHSM_MAJOR_VERSION}" = "2"])
225
226AC_SUBST(MODULE_CFLAGS)
227AC_SUBST(MODULE_LIBS)
228
229# assign default values to TEST_HOST and TEST_IP if necessary
230: ${TEST_HOST:="localhost"}
231: ${TEST_IP:="[[::1]] 127.0.0.1"}
232AC_ARG_VAR([TEST_HOST], [Host name to use for server instances started by \
233                        "make check", must resolve to addresses in TEST_IP. \
234                        The default is "localhost".])
235AC_ARG_VAR([TEST_IP], [List of IP addresses to use for server instances \
236                      started by "make check". The default is \
237                      "[::1] 127.0.0.1". Note that IPv6 addresses must be \
238                      enclosed in square brackets.])
239AM_SUBST_NOTMAKE(TEST_IP)
240
241: ${TEST_LOCK_WAIT:="30"}
242: ${TEST_QUERY_TIMEOUT:="30"}
243AC_ARG_VAR([TEST_LOCK_WAIT], [Timeout in seconds to acquire locks for \
244                             Apache instances in the test suite, or the \
245                             previous instance to remove its PID file if \
246                             flock is not used. Default is 30.])
247AC_ARG_VAR([TEST_QUERY_TIMEOUT], [Timeout in seconds for HTTPS requests \
248                                 sent using gnutls-cli in the test suite. \
249                                 Default is 30.])
250
251dnl Allow user to set SoftHSM PKCS #11 module
252AC_ARG_VAR([SOFTHSM_LIB], [Absolute path of the SoftHSM PKCS @%:@11 module to \
253                          use. By default the test suite will search common \
254                          library paths.])
255
256dnl Build list of "Listen" statements for Apache
257LISTEN_LIST="@%:@ Listen addresses for the test servers"
258for i in ${TEST_IP}; do
259        LISTEN_LIST="${LISTEN_LIST}
260Listen ${i}:\${TEST_PORT}"
261done
262# Available extra ports, tests can "Define" variables of the listed
263# names in their apache.conf to enable them.
264for j in TEST_HTTP_PORT; do
265LISTEN_LIST="${LISTEN_LIST}
266<IfDefine ${j}>"
267for i in ${TEST_IP}; do
268        LISTEN_LIST="${LISTEN_LIST}
269        Listen ${i}:\${${j}}"
270done
271LISTEN_LIST="${LISTEN_LIST}
272</IfDefine>"
273done
274AC_SUBST(LISTEN_LIST)
275AM_SUBST_NOTMAKE(LISTEN_LIST)
276
277DX_DOXYGEN_FEATURE(ON)
278DX_DOT_FEATURE(ON)
279DX_HTML_FEATURE(ON)
280DX_MAN_FEATURE(OFF)
281DX_RTF_FEATURE(OFF)
282DX_XML_FEATURE(OFF)
283DX_PDF_FEATURE(ON)
284DX_PS_FEATURE(OFF)
285DX_INIT_DOXYGEN([mod_gnutls], [doc/doxygen.conf], [doc/api])
286
287AC_CONFIG_FILES([Makefile src/Makefile test/Makefile test/tests/Makefile \
288                        doc/Makefile doc/doxygen.conf include/mod_gnutls.h \
289                        test/proxy_backend.conf test/ocsp_server.conf \
290                        test/apache-conf/listen.conf \
291                        test/apache-conf/netns.conf])
292AC_OUTPUT
293
294echo "---"
295echo "Configuration summary for mod_gnutls:"
296echo ""
297echo "   * mod_gnutls version:  ${MOD_GNUTLS_VERSION}"
298echo "   * Apache Modules directory:    ${AP_LIBEXECDIR}"
299echo "   * GnuTLS Library version:      ${LIBGNUTLS_VERSION}"
300echo "   * CFLAGS for GnuTLS:           ${LIBGNUTLS_CFLAGS}"
301echo "   * LDFLAGS for GnuTLS:  ${LIBGNUTLS_LIBS}"
302echo "   * SRP Authentication:  ${use_srp}"
303echo "   * MSVA Client Verification:    ${use_msva}"
304echo "   * Build documentation: ${build_doc}"
305echo ""
306echo "---"
Note: See TracBrowser for help on using the repository browser.