]>
Commit | Line | Data |
---|---|---|
f2b508c1 TB |
1 | # |
2 | # Copyright (C) 2007-2013 Tobias Brunner | |
3 | # Copyright (C) 2006-2013 Andreas Steffen | |
4 | # Copyright (C) 2006-2013 Martin Willi | |
5 | # Hochschule fuer Technik Rapperswil | |
6 | # | |
7 | # This program is free software; you can redistribute it and/or modify it | |
8 | # under the terms of the GNU General Public License as published by the | |
9 | # Free Software Foundation; either version 2 of the License, or (at your | |
10 | # option) any later version. See <http://www.fsf.org/copyleft/gpl.txt>. | |
11 | # | |
12 | # This program is distributed in the hope that it will be useful, but | |
13 | # WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY | |
14 | # or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
15 | # for more details. | |
16 | # | |
17 | ||
18 | # ============================ | |
19 | # initialize & set some vars | |
20 | # ============================ | |
f2c2d395 | 21 | |
e8b8a6d9 | 22 | AC_INIT([strongSwan],[5.1.0]) |
5e5f0bd4 | 23 | AM_INIT_AUTOMAKE(tar-ustar) |
84c00e71 | 24 | m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES]) |
e455ae13 | 25 | AC_CONFIG_MACRO_DIR([m4/config]) |
7300eb29 | 26 | AC_CONFIG_HEADERS([config.h]) |
4c311ffb | 27 | AC_DEFINE([CONFIG_H_INCLUDED], [], [defined if config.h included]) |
a47486b5 | 28 | PKG_PROG_PKG_CONFIG |
f2c2d395 | 29 | |
f2b508c1 TB |
30 | # ================================= |
31 | # check --enable-xxx & --with-xxx | |
32 | # ================================= | |
db26d00e | 33 | |
b7b56533 MW |
34 | m4_include(m4/macros/with.m4) |
35 | ||
b7b56533 MW |
36 | ARG_WITH_SUBST([random-device], [/dev/random], [set the device to read real random data from]) |
37 | ARG_WITH_SUBST([urandom-device], [/dev/urandom], [set the device to read pseudo random data from]) | |
38 | ARG_WITH_SUBST([strongswan-conf], [${sysconfdir}/strongswan.conf], [set the strongswan.conf file location]) | |
39 | ARG_WITH_SUBST([resolv-conf], [${sysconfdir}/resolv.conf], [set the file to use in DNS handler plugin]) | |
40 | ARG_WITH_SUBST([piddir], [/var/run], [set path for PID and UNIX socket files]) | |
41 | ARG_WITH_SUBST([ipsecdir], [${libexecdir%/}/ipsec], [set installation path for ipsec tools]) | |
60d62b9e TB |
42 | ARG_WITH_SUBST([ipseclibdir], [${libdir%/}/ipsec], [set installation path for ipsec libraries]) |
43 | ARG_WITH_SUBST([plugindir], [${ipseclibdir%/}/plugins], [set the installation path of plugins]) | |
19db8e9e | 44 | ARG_WITH_SUBST([imcvdir], [${ipseclibdir%/}/imcvs], [set the installation path of IMC and IMV dynamic librariers]) |
b64f3336 | 45 | ARG_WITH_SUBST([nm-ca-dir], [/usr/share/ca-certificates], [directory the NM backend uses to look up trusted root certificates]) |
b7b56533 MW |
46 | ARG_WITH_SUBST([linux-headers], [\${top_srcdir}/src/include], [set directory of linux header files to use]) |
47 | ARG_WITH_SUBST([routing-table], [220], [set routing table to use for IPsec routes]) | |
48 | ARG_WITH_SUBST([routing-table-prio], [220], [set priority for IPsec routing table]) | |
bc6d9447 | 49 | ARG_WITH_SUBST([ipsec-script], [ipsec], [change the name of the ipsec script]) |
f4de6496 | 50 | ARG_WITH_SUBST([fips-mode], [0], [set openssl FIPS mode: disabled(0), enabled(1), Suite B enabled(2)]) |
b7b56533 | 51 | |
44566c22 | 52 | ARG_WITH_SET([tss], [no], [set implementation of the Trusted Computing Group's Software Stack (TSS). Currently the only supported value is "trousers"]) |
946be4d3 | 53 | ARG_WITH_SET([capabilities], [no], [set capability dropping library. Currently supported values are "libcap" and "native"]) |
3e35a6e7 | 54 | ARG_WITH_SET([mpz_powm_sec], [yes], [use the more side-channel resistant mpz_powm_sec in libgmp, if available]) |
b188f231 | 55 | ARG_WITH_SET([dev-headers], [no], [install strongSwan development headers to directory.]) |
db26d00e | 56 | |
fc16b361 MV |
57 | if test -n "$PKG_CONFIG"; then |
58 | systemdsystemunitdir_default=$($PKG_CONFIG --variable=systemdsystemunitdir systemd) | |
59 | fi | |
60 | ARG_WITH_SET([systemdsystemunitdir], [$systemdsystemunitdir_default], [directory for systemd service files]) | |
61 | AM_CONDITIONAL(HAVE_SYSTEMD, [test -n "$systemdsystemunitdir" -a "x$systemdsystemunitdir" != xno]) | |
62 | AC_SUBST(systemdsystemunitdir) | |
63 | ||
25b12c69 MW |
64 | AC_ARG_WITH( |
65 | [user], | |
c7e0f07c | 66 | AS_HELP_STRING([--with-user=user],[change user of the daemons to "user" after startup (default is "root").]), |
a4037686 MW |
67 | [AC_DEFINE_UNQUOTED([IPSEC_USER], "$withval", [username to run daemon with]) |
68 | AC_SUBST(ipsecuser, "$withval")], | |
25b12c69 MW |
69 | [AC_SUBST(ipsecuser, "root")] |
70 | ) | |
71 | ||
72 | AC_ARG_WITH( | |
73 | [group], | |
c7e0f07c | 74 | AS_HELP_STRING([--with-group=group],[change group of the daemons to "group" after startup (default is "root").]), |
a4037686 MW |
75 | [AC_DEFINE_UNQUOTED(IPSEC_GROUP, "$withval", [groupname to run daemon with]) |
76 | AC_SUBST(ipsecgroup, "$withval")], | |
25b12c69 | 77 | [AC_SUBST(ipsecgroup, "root")] |
6874bf69 MW |
78 | ) |
79 | ||
e7ea057f TB |
80 | AC_ARG_WITH( |
81 | [charon-udp-port], | |
224ab4c5 | 82 | AS_HELP_STRING([--with-charon-udp-port=port],[UDP port used by charon locally (default 500). Set to 0 to allocate randomly.]), |
e7ea057f TB |
83 | [AC_DEFINE_UNQUOTED(CHARON_UDP_PORT, [$withval], [UDP port used by charon locally]) |
84 | AC_SUBST(charon_udp_port, [$withval])], | |
85 | [AC_SUBST(charon_udp_port, 500)] | |
86 | ) | |
87 | ||
88 | AC_ARG_WITH( | |
89 | [charon-natt-port], | |
224ab4c5 | 90 | AS_HELP_STRING([--with-charon-natt-port=port],[UDP port used by charon locally in case a NAT is detected (must be different from charon-udp-port, default 4500). Set to 0 to allocate randomly.]), |
e7ea057f TB |
91 | [AC_DEFINE_UNQUOTED(CHARON_NATT_PORT, [$withval], [UDP post used by charon locally in case a NAT is detected]) |
92 | AC_SUBST(charon_natt_port, [$withval])], | |
93 | [AC_SUBST(charon_natt_port, 4500)] | |
94 | ) | |
95 | ||
96 | AC_MSG_CHECKING([configured UDP ports ($charon_udp_port, $charon_natt_port)]) | |
224ab4c5 | 97 | if test x$charon_udp_port != x0 -a x$charon_udp_port = x$charon_natt_port; then |
e7ea057f TB |
98 | AC_MSG_ERROR(the ports have to be different) |
99 | else | |
100 | AC_MSG_RESULT(ok) | |
101 | fi | |
102 | ||
bc6d9447 TB |
103 | # convert script name to uppercase |
104 | AC_SUBST(ipsec_script_upper, [`echo -n "$ipsec_script" | tr a-z A-Z`]) | |
105 | ||
b803bc82 MW |
106 | m4_include(m4/macros/enable-disable.m4) |
107 | ||
108 | ARG_ENABL_SET([curl], [enable CURL fetcher plugin to fetch files via libcurl. Requires libcurl.]) | |
9f963a7c | 109 | ARG_ENABL_SET([unbound], [enable UNBOUND resolver plugin to perform DNS queries via libunbound. Requires libldns and libunbound.]) |
2ca52c80 | 110 | ARG_ENABL_SET([soup], [enable soup fetcher plugin to fetch from HTTP via libsoup. Requires libsoup.]) |
b803bc82 MW |
111 | ARG_ENABL_SET([ldap], [enable LDAP fetching plugin to fetch files via libldap. Requires openLDAP.]) |
112 | ARG_DISBL_SET([aes], [disable AES software implementation plugin.]) | |
113 | ARG_DISBL_SET([des], [disable DES/3DES software implementation plugin.]) | |
114 | ARG_ENABL_SET([blowfish], [enable Blowfish software implementation plugin.]) | |
9d4fc867 | 115 | ARG_DISBL_SET([rc2], [disable RC2 software implementation plugin.]) |
b803bc82 MW |
116 | ARG_ENABL_SET([md4], [enable MD4 software implementation plugin.]) |
117 | ARG_DISBL_SET([md5], [disable MD5 software implementation plugin.]) | |
118 | ARG_DISBL_SET([sha1], [disable SHA1 software implementation plugin.]) | |
119 | ARG_DISBL_SET([sha2], [disable SHA256/SHA384/SHA512 software implementation plugin.]) | |
120 | ARG_DISBL_SET([fips-prf], [disable FIPS PRF software implementation plugin.]) | |
121 | ARG_DISBL_SET([gmp], [disable GNU MP (libgmp) based crypto implementation plugin.]) | |
ed8dc6f1 | 122 | ARG_ENABL_SET([rdrand], [enable Intel RDRAND random generator plugin.]) |
b803bc82 | 123 | ARG_DISBL_SET([random], [disable RNG implementation on top of /dev/(u)random.]) |
04024b5d | 124 | ARG_DISBL_SET([nonce], [disable nonce generation plugin.]) |
b803bc82 | 125 | ARG_DISBL_SET([x509], [disable X509 certificate implementation plugin.]) |
c2e5cee4 | 126 | ARG_DISBL_SET([revocation], [disable X509 CRL/OCSP revocation check plugin.]) |
01d30381 | 127 | ARG_DISBL_SET([constraints], [disable advanced X509 constraint checking plugin.]) |
b803bc82 MW |
128 | ARG_DISBL_SET([pubkey], [disable RAW public key support plugin.]) |
129 | ARG_DISBL_SET([pkcs1], [disable PKCS1 key decoding plugin.]) | |
bd20f040 | 130 | ARG_DISBL_SET([pkcs7], [disable PKCS7 container support plugin.]) |
5ec525c1 | 131 | ARG_DISBL_SET([pkcs8], [disable PKCS8 private key decoding plugin.]) |
feef6373 | 132 | ARG_DISBL_SET([pkcs12], [disable PKCS12 container support plugin.]) |
b803bc82 MW |
133 | ARG_DISBL_SET([pgp], [disable PGP key decoding plugin.]) |
134 | ARG_DISBL_SET([dnskey], [disable DNS RR key decoding plugin.]) | |
584d656b | 135 | ARG_DISBL_SET([sshkey], [disable SSH key decoding plugin.]) |
a77bbc3b | 136 | ARG_ENABL_SET([ipseckey], [enable IPSECKEY authentication plugin.]) |
b803bc82 MW |
137 | ARG_DISBL_SET([pem], [disable PEM decoding plugin.]) |
138 | ARG_DISBL_SET([hmac], [disable HMAC crypto implementation plugin.]) | |
c0d39c20 | 139 | ARG_DISBL_SET([cmac], [disable CMAC crypto implementation plugin.]) |
b803bc82 | 140 | ARG_DISBL_SET([xcbc], [disable xcbc crypto implementation plugin.]) |
71c87e34 | 141 | ARG_ENABL_SET([af-alg], [enable AF_ALG crypto interface to Linux Crypto API.]) |
b803bc82 MW |
142 | ARG_ENABL_SET([test-vectors], [enable plugin providing crypto test vectors.]) |
143 | ARG_ENABL_SET([mysql], [enable MySQL database support. Requires libmysqlclient_r.]) | |
144 | ARG_ENABL_SET([sqlite], [enable SQLite database support. Requires libsqlite3.]) | |
6d599fb9 | 145 | ARG_DISBL_SET([stroke], [disable charons stroke configuration backend.]) |
b803bc82 MW |
146 | ARG_ENABL_SET([medsrv], [enable mediation server web frontend and daemon plugin.]) |
147 | ARG_ENABL_SET([medcli], [enable mediation client configuration database plugin.]) | |
148 | ARG_ENABL_SET([smp], [enable SMP configuration and control interface. Requires libxml.]) | |
149 | ARG_ENABL_SET([sql], [enable SQL database configuration backend.]) | |
b803bc82 MW |
150 | ARG_ENABL_SET([leak-detective], [enable malloc hooks to find memory leaks.]) |
151 | ARG_ENABL_SET([lock-profiler], [enable lock/mutex profiling code.]) | |
61706107 | 152 | ARG_ENABL_SET([unit-tester], [enable unit tests on IKEv2 daemon startup.]) |
b76b867c | 153 | ARG_ENABL_SET([load-tester], [enable load testing plugin for IKEv2 daemon.]) |
68eb610d | 154 | ARG_ENABL_SET([eap-sim], [enable SIM authentication module for EAP.]) |
b803bc82 | 155 | ARG_ENABL_SET([eap-sim-file], [enable EAP-SIM backend based on a triplet file.]) |
80dca77a | 156 | ARG_ENABL_SET([eap-sim-pcsc], [enable EAP-SIM backend based on a smartcard reader. Requires libpcsclite.]) |
39468219 MW |
157 | ARG_ENABL_SET([eap-aka], [enable EAP AKA authentication module.]) |
158 | ARG_ENABL_SET([eap-aka-3gpp2], [enable EAP AKA backend implementing 3GPP2 algorithms in software. Requires libgmp.]) | |
d2c35874 | 159 | ARG_ENABL_SET([eap-simaka-sql], [enable EAP-SIM/AKA backend based on a triplet/quintuplet SQL database.]) |
edcb2dd3 MW |
160 | ARG_ENABL_SET([eap-simaka-pseudonym], [enable EAP-SIM/AKA pseudonym storage plugin.]) |
161 | ARG_ENABL_SET([eap-simaka-reauth], [enable EAP-SIM/AKA reauthentication data storage plugin.]) | |
b803bc82 | 162 | ARG_ENABL_SET([eap-identity], [enable EAP module providing EAP-Identity helper.]) |
68eb610d | 163 | ARG_ENABL_SET([eap-md5], [enable EAP MD5 (CHAP) authentication module.]) |
9ede42e1 | 164 | ARG_ENABL_SET([eap-gtc], [enable EAP GTC authentication module.]) |
68eb610d AS |
165 | ARG_ENABL_SET([eap-mschapv2], [enable EAP MS-CHAPv2 authentication module.]) |
166 | ARG_ENABL_SET([eap-tls], [enable EAP TLS authentication module.]) | |
167 | ARG_ENABL_SET([eap-ttls], [enable EAP TTLS authentication module.]) | |
1be296df | 168 | ARG_ENABL_SET([eap-peap], [enable EAP PEAP authentication module.]) |
d93e2e54 | 169 | ARG_ENABL_SET([eap-tnc], [enable EAP TNC trusted network connect module.]) |
700ff5de | 170 | ARG_ENABL_SET([eap-dynamic], [enable dynamic EAP proxy module.]) |
68eb610d | 171 | ARG_ENABL_SET([eap-radius], [enable RADIUS proxy authentication module.]) |
4f07a19d | 172 | ARG_DISBL_SET([xauth-generic], [disable generic XAuth backend.]) |
85fc1eb6 | 173 | ARG_ENABL_SET([xauth-eap], [enable XAuth backend using EAP methods to verify passwords.]) |
b9e49163 | 174 | ARG_ENABL_SET([xauth-pam], [enable XAuth backend using PAM to verify passwords.]) |
e4013bb9 | 175 | ARG_ENABL_SET([xauth-noauth], [enable XAuth pseudo-backend that does not actually verify or even request any credentials.]) |
45e2be23 | 176 | ARG_ENABL_SET([tnc-ifmap], [enable TNC IF-MAP module. Requires libxml]) |
70fd2d1a | 177 | ARG_ENABL_SET([tnc-pdp], [enable TNC policy decision point module.]) |
8dcc56dc AS |
178 | ARG_ENABL_SET([tnc-imc], [enable TNC IMC module.]) |
179 | ARG_ENABL_SET([tnc-imv], [enable TNC IMV module.]) | |
b885c3cd | 180 | ARG_ENABL_SET([tnccs-11], [enable TNCCS 1.1 protocol module. Requires libxml]) |
6d0e9cf0 | 181 | ARG_ENABL_SET([tnccs-20], [enable TNCCS 2.0 protocol module.]) |
f652995b | 182 | ARG_ENABL_SET([tnccs-dynamic], [enable dynamic TNCCS protocol discovery module.]) |
510f37ab AS |
183 | ARG_ENABL_SET([imc-test], [enable IMC test module.]) |
184 | ARG_ENABL_SET([imv-test], [enable IMV test module.]) | |
d9cdab92 AS |
185 | ARG_ENABL_SET([imc-scanner], [enable IMC port scanner module.]) |
186 | ARG_ENABL_SET([imv-scanner], [enable IMV port scanner module.]) | |
e9f47ee2 AS |
187 | ARG_ENABL_SET([imc-os], [enable IMC operating system module.]) |
188 | ARG_ENABL_SET([imv-os], [enable IMV operating system module.]) | |
4a492a8d AS |
189 | ARG_ENABL_SET([imc-attestation],[enable IMC attestation module.]) |
190 | ARG_ENABL_SET([imv-attestation],[enable IMV attestation module.]) | |
b803bc82 MW |
191 | ARG_DISBL_SET([kernel-netlink], [disable the netlink kernel interface.]) |
192 | ARG_ENABL_SET([kernel-pfkey], [enable the PF_KEY kernel interface.]) | |
193 | ARG_ENABL_SET([kernel-pfroute], [enable the PF_ROUTE kernel interface.]) | |
194 | ARG_ENABL_SET([kernel-klips], [enable the KLIPS kernel interface.]) | |
279e0d42 | 195 | ARG_ENABL_SET([kernel-libipsec],[enable the libipsec kernel interface.]) |
b70139fb | 196 | ARG_ENABL_SET([libipsec], [enable user space IPsec implementation.]) |
dab05604 | 197 | ARG_DISBL_SET([socket-default], [disable default socket implementation for charon.]) |
9ed1bb48 | 198 | ARG_ENABL_SET([socket-dynamic], [enable dynamic socket implementation for charon]) |
0d7b48a3 | 199 | ARG_ENABL_SET([farp], [enable ARP faking plugin that responds to ARP requests to peers virtual IP]) |
b803bc82 MW |
200 | ARG_ENABL_SET([dumm], [enable the DUMM UML test framework.]) |
201 | ARG_ENABL_SET([fast], [enable libfast (FastCGI Application Server w/ templates.]) | |
202 | ARG_ENABL_SET([manager], [enable web management console (proof of concept).]) | |
203 | ARG_ENABL_SET([mediation], [enable IKEv2 Mediation Extension.]) | |
204 | ARG_ENABL_SET([integrity-test], [enable integrity testing of libstrongswan and plugins.]) | |
6d599fb9 | 205 | ARG_DISBL_SET([load-warning], [disable the charon plugin load option warning in starter.]) |
ccdd3a4c | 206 | ARG_DISBL_SET([ikev1], [disable IKEv1 protocol support in charon.]) |
e51a28fd | 207 | ARG_DISBL_SET([ikev2], [disable IKEv2 protocol support in charon.]) |
e51a28fd | 208 | ARG_DISBL_SET([charon], [disable the IKEv1/IKEv2 keying daemon charon.]) |
b803bc82 MW |
209 | ARG_DISBL_SET([tools], [disable additional utilities (openac, scepclient and pki).]) |
210 | ARG_DISBL_SET([scripts], [disable additional utilities (found in directory scripts).]) | |
e78ec86d | 211 | ARG_ENABL_SET([conftest], [enforce Suite B conformance test framework.]) |
b803bc82 MW |
212 | ARG_DISBL_SET([updown], [disable updown firewall script plugin.]) |
213 | ARG_DISBL_SET([attr], [disable strongswan.conf based configuration attribute plugin.]) | |
24779482 | 214 | ARG_ENABL_SET([attr-sql], [enable SQL based configuration attribute plugin.]) |
beaa048e | 215 | ARG_ENABL_SET([dhcp], [enable DHCP based attribute provider plugin.]) |
4819ec6a | 216 | ARG_DISBL_SET([resolve], [disable resolve DNS handler plugin.]) |
b803bc82 MW |
217 | ARG_ENABL_SET([padlock], [enables VIA Padlock crypto plugin.]) |
218 | ARG_ENABL_SET([openssl], [enables the OpenSSL crypto plugin.]) | |
219 | ARG_ENABL_SET([gcrypt], [enables the libgcrypt plugin.]) | |
220 | ARG_ENABL_SET([agent], [enables the ssh-agent signing plugin.]) | |
7b8edabd | 221 | ARG_ENABL_SET([keychain], [enables OS X Keychain Services credential set.]) |
6e862e21 | 222 | ARG_ENABL_SET([pkcs11], [enables the PKCS11 token support plugin.]) |
272f0e1a | 223 | ARG_ENABL_SET([ctr], [enables the Counter Mode wrapper crypto plugin.]) |
80a93a13 | 224 | ARG_ENABL_SET([ccm], [enables the CCM AEAD wrapper crypto plugin.]) |
1a649810 | 225 | ARG_ENABL_SET([gcm], [enables the GCM AEAD wrapper crypto plugin.]) |
5f9e62c5 | 226 | ARG_ENABL_SET([addrblock], [enables RFC 3779 address block constraint support.]) |
5ff012f7 | 227 | ARG_ENABL_SET([unity], [enables Cisco Unity extension plugin.]) |
b803bc82 | 228 | ARG_ENABL_SET([uci], [enable OpenWRT UCI configuration plugin.]) |
45dcf4df | 229 | ARG_ENABL_SET([osx-attr], [enable OS X SystemConfiguration attribute handler.]) |
9804fcce | 230 | ARG_ENABL_SET([android-dns], [enable Android specific DNS handler.]) |
162621ed | 231 | ARG_ENABL_SET([android-log], [enable Android specific logger plugin.]) |
f79161e8 | 232 | ARG_ENABL_SET([maemo], [enable Maemo specific plugin.]) |
1c7a733e | 233 | ARG_ENABL_SET([nm], [enable NetworkManager backend.]) |
e67f5136 | 234 | ARG_ENABL_SET([ha], [enable high availability cluster plugin.]) |
5e603aba | 235 | ARG_ENABL_SET([whitelist], [enable peer identity whitelisting plugin.]) |
e0d7c1ed | 236 | ARG_ENABL_SET([lookip], [enable fast virtual IP lookup and notification plugin.]) |
0aaf5ccf | 237 | ARG_ENABL_SET([error-notify], [enable error notification plugin.]) |
ba2201ed | 238 | ARG_ENABL_SET([certexpire], [enable CSV export of expiration dates of used certificates.]) |
0ed31e72 | 239 | ARG_ENABL_SET([systime-fix], [enable plugin to handle cert lifetimes with invalid system time gracefully.]) |
30cd31fb | 240 | ARG_ENABL_SET([led], [enable plugin to control LEDs on IKEv2 activity using the Linux kernel LED subsystem.]) |
3e74ebbe | 241 | ARG_ENABL_SET([duplicheck], [advanced duplicate checking plugin using liveness checks.]) |
007c4708 | 242 | ARG_ENABL_SET([coupling], [enable IKEv2 plugin to couple peer certificates permanently to authentication.]) |
caf4b88e | 243 | ARG_ENABL_SET([radattr], [enable plugin to inject and process custom RADIUS attributes as IKEv2 client.]) |
b803bc82 | 244 | ARG_ENABL_SET([vstr], [enforce using the Vstr string library to replace glibc-like printf hooks.]) |
3372ad14 | 245 | ARG_ENABL_SET([monolithic], [build monolithic version of libstrongswan that includes all enabled plugins. Similarly, the plugins of charon are assembled in libcharon.]) |
4c6c9346 | 246 | ARG_ENABL_SET([bfd-backtraces], [use binutils libbfd to resolve backtraces for memory leaks and segfaults.]) |
83714577 | 247 | ARG_ENABL_SET([unwind-backtraces],[use libunwind to create backtraces for memory leaks and segfaults.]) |
0aa5a466 | 248 | ARG_ENABL_SET([unit-tests], [enable unit tests using the check test framework.]) |
1f14b4a1 | 249 | ARG_ENABL_SET([coverage], [enable lcov coverage report generation.]) |
559fe48c | 250 | ARG_ENABL_SET([tkm], [enable Trusted Key Manager support.]) |
1fed10be | 251 | ARG_ENABL_SET([cmd], [enable the command line IKE client charon-cmd.]) |
bf45d6dd | 252 | |
f2b508c1 TB |
253 | # =================================== |
254 | # option to disable default options | |
255 | # =================================== | |
eaf752d2 TB |
256 | |
257 | ARG_DISBL_SET([defaults], [disable all default plugins (they can be enabled with their respective --enable options)]) | |
258 | ||
259 | if test x$defaults = xfalse; then | |
260 | for option in $enabled_by_default; do | |
261 | eval test x\${${option}_given} = xtrue && continue | |
262 | let $option=false | |
263 | done | |
264 | fi | |
265 | ||
f2b508c1 TB |
266 | # =========================== |
267 | # set up compiler and flags | |
268 | # =========================== | |
be0a03be MW |
269 | |
270 | if test -z "$CFLAGS"; then | |
8ed3c9fb | 271 | CFLAGS="-g -O2 -Wall -Wno-format -Wno-pointer-sign" |
be0a03be MW |
272 | fi |
273 | AC_PROG_CC | |
0aa5a466 AKR |
274 | AM_PROG_CC_C_O |
275 | ||
f5410905 | 276 | AC_LIB_PREFIX |
be0a03be MW |
277 | AC_C_BIGENDIAN |
278 | ||
f2b508c1 TB |
279 | # ========================= |
280 | # check required programs | |
281 | # ========================= | |
f2c2d395 | 282 | |
39a6c395 | 283 | LT_INIT |
f2c2d395 | 284 | AC_PROG_INSTALL |
7d2b06da | 285 | AC_PROG_EGREP |
69fc7820 | 286 | AC_PROG_AWK |
f2c2d395 MW |
287 | AC_PROG_LEX |
288 | AC_PROG_YACC | |
298b06c2 | 289 | AC_PATH_PROG([PERL], [perl], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) |
69fc7820 TB |
290 | AC_PATH_PROG([GPERF], [gperf], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) |
291 | ||
f2b508c1 | 292 | # because gperf is not needed by end-users we just report it but do not abort on failure |
69fc7820 TB |
293 | AC_MSG_CHECKING([gperf version >= 3.0.0]) |
294 | if test -x "$GPERF"; then | |
295 | if test "`$GPERF --version | $AWK -F' ' '/^GNU gperf/ { print $3 }' | $AWK -F. '{ print $1 }'`" -ge "3"; then | |
296 | AC_MSG_RESULT([yes]) | |
297 | else | |
298 | AC_MSG_RESULT([no]) | |
299 | fi | |
300 | else | |
301 | AC_MSG_RESULT([not found]) | |
302 | fi | |
f2c2d395 | 303 | |
f2b508c1 TB |
304 | # ======================== |
305 | # dependency calculation | |
306 | # ======================== | |
f2c2d395 | 307 | |
720ba902 TB |
308 | if test x$xauth_generic_given = xfalse -a x$ikev1 = xfalse; then |
309 | xauth_generic=false; | |
310 | fi | |
311 | ||
279e0d42 TB |
312 | if test x$kernel_libipsec = xtrue; then |
313 | libipsec=true; | |
314 | fi | |
315 | ||
47208157 | 316 | if test x$eap_aka_3gpp2 = xtrue; then |
a998276a | 317 | gmp=true; |
47208157 MW |
318 | fi |
319 | ||
320 | if test x$eap_aka = xtrue; then | |
a998276a | 321 | fips_prf=true; |
f8330d03 | 322 | simaka=true; |
a998276a MW |
323 | fi |
324 | ||
325 | if test x$eap_sim = xtrue; then | |
326 | fips_prf=true; | |
f8330d03 | 327 | simaka=true; |
a998276a MW |
328 | fi |
329 | ||
1be296df | 330 | if test x$eap_tls = xtrue -o x$eap_ttls = xtrue -o x$eap_peap = xtrue; then |
0f82a470 MW |
331 | tls=true; |
332 | fi | |
333 | ||
21b0f216 | 334 | if test x$eap_radius = xtrue -o x$radattr = xtrue -o x$tnc_pdp = xtrue; then |
f0f94e2c MW |
335 | radius=true; |
336 | fi | |
337 | ||
f3d6b9c8 | 338 | if test x$tnc_imc = xtrue -o x$tnc_imv = xtrue -o x$tnccs_11 = xtrue -o x$tnccs_11 = xtrue -o x$tnccs_dynamic = xtrue -o x$eap_tnc = xtrue; then |
b08505da | 339 | tnc_tnccs=true; |
f0fa002f AS |
340 | fi |
341 | ||
e9f47ee2 | 342 | if test x$imc_test = xtrue -o x$imv_test = xtrue -o x$imc_scanner = xtrue -o x$imv_scanner = xtrue -o x$imc_os = xtrue -o x$imv_os = xtrue -o x$imc_attestation = xtrue -o x$imv_attestation = xtrue; then |
510f37ab AS |
343 | imcv=true; |
344 | fi | |
345 | ||
3ed943c3 AS |
346 | if test x$imc_attestation = xtrue -o x$imv_attestation = xtrue; then |
347 | pts=true; | |
348 | fi | |
349 | ||
a998276a | 350 | if test x$fips_prf = xtrue; then |
40f130da MW |
351 | if test x$openssl = xfalse; then |
352 | sha1=true; | |
353 | fi | |
a998276a MW |
354 | fi |
355 | ||
45e2be23 | 356 | if test x$smp = xtrue -o x$tnccs_11 = xtrue -o x$tnc_ifmap = xtrue; then |
6b9290ff MW |
357 | xml=true |
358 | fi | |
359 | ||
360 | if test x$manager = xtrue; then | |
361 | fast=true | |
362 | fi | |
363 | ||
782db7ed | 364 | if test x$medsrv = xtrue; then |
a7f79ee9 | 365 | mediation=true |
9529fb68 | 366 | fast=true |
782db7ed MW |
367 | fi |
368 | ||
369 | if test x$medcli = xtrue; then | |
a7f79ee9 | 370 | mediation=true |
782db7ed MW |
371 | fi |
372 | ||
1f14b4a1 TB |
373 | if test x$coverage = xtrue; then |
374 | unit_tests=true | |
375 | fi | |
376 | ||
f2b508c1 TB |
377 | # =========================================== |
378 | # check required libraries and header files | |
379 | # =========================================== | |
a9f56adb TB |
380 | |
381 | AC_HEADER_STDBOOL | |
8b6a5ce5 | 382 | AC_FUNC_ALLOCA |
2a595276 | 383 | AC_FUNC_STRERROR_R |
6b9290ff | 384 | |
f2b508c1 TB |
385 | # libraries needed on some platforms but not on others |
386 | # ------------------------------------------------------ | |
ea7e89c7 | 387 | saved_LIBS=$LIBS |
3974b2fb | 388 | |
f2b508c1 | 389 | # FreeBSD and Mac OS X have dlopen integrated in libc, Linux needs libdl |
ea7e89c7 TB |
390 | LIBS="" |
391 | AC_SEARCH_LIBS(dlopen, dl, [DLLIB=$LIBS]) | |
ea7e89c7 TB |
392 | AC_SUBST(DLLIB) |
393 | ||
f2b508c1 | 394 | # glibc's backtrace() can be replicated on FreeBSD with libexecinfo |
3974b2fb TB |
395 | LIBS="" |
396 | AC_SEARCH_LIBS(backtrace, execinfo, [BTLIB=$LIBS]) | |
397 | AC_CHECK_FUNCS(backtrace) | |
398 | AC_SUBST(BTLIB) | |
399 | ||
f2b508c1 | 400 | # OpenSolaris needs libsocket and libnsl for socket() |
26965b4e TB |
401 | LIBS="" |
402 | AC_SEARCH_LIBS(socket, socket, [SOCKLIB=$LIBS], | |
403 | [AC_CHECK_LIB(nsl, socket, [SOCKLIB="-lsocket -lnsl"], [], [-lsocket])] | |
404 | ) | |
405 | AC_SUBST(SOCKLIB) | |
406 | ||
f2b508c1 | 407 | # FreeBSD has clock_gettime in libc, Linux needs librt |
3f310c0d MW |
408 | LIBS="" |
409 | AC_SEARCH_LIBS(clock_gettime, rt, [RTLIB=$LIBS]) | |
410 | AC_CHECK_FUNCS(clock_gettime) | |
411 | AC_SUBST(RTLIB) | |
412 | ||
f2b508c1 | 413 | # Android has pthread_* functions in bionic (libc), others need libpthread |
070ac5b0 TB |
414 | LIBS="" |
415 | AC_SEARCH_LIBS(pthread_create, pthread, [PTHREADLIB=$LIBS]) | |
416 | AC_SUBST(PTHREADLIB) | |
417 | ||
3974b2fb | 418 | LIBS=$saved_LIBS |
f2b508c1 | 419 | # ------------------------------------------------------ |
3974b2fb | 420 | |
4f734a55 | 421 | AC_MSG_CHECKING(for dladdr) |
39a6c395 TB |
422 | AC_COMPILE_IFELSE( |
423 | [AC_LANG_PROGRAM( | |
424 | [[#define _GNU_SOURCE | |
425 | #include <dlfcn.h>]], | |
426 | [[Dl_info* info = 0; | |
427 | dladdr(0, info);]])], | |
a4037686 | 428 | [AC_MSG_RESULT([yes]); AC_DEFINE([HAVE_DLADDR], [], [have dladdr()])], |
4f734a55 MW |
429 | [AC_MSG_RESULT([no])] |
430 | ) | |
431 | ||
f2b508c1 | 432 | # check if pthread_condattr_setclock(CLOCK_MONOTONE) is supported |
3d5818ec | 433 | saved_LIBS=$LIBS |
070ac5b0 | 434 | LIBS=$PTHREADLIB |
3d5818ec | 435 | AC_MSG_CHECKING([for pthread_condattr_setclock(CLOCK_MONOTONE)]) |
39a6c395 TB |
436 | AC_RUN_IFELSE( |
437 | [AC_LANG_SOURCE( | |
438 | [[#include <pthread.h> | |
439 | int main() { pthread_condattr_t attr; | |
440 | pthread_condattr_init(&attr); | |
441 | return pthread_condattr_setclock(&attr, CLOCK_MONOTONIC);}]])], | |
a4037686 MW |
442 | [AC_MSG_RESULT([yes]); |
443 | AC_DEFINE([HAVE_CONDATTR_CLOCK_MONOTONIC], [], | |
444 | [pthread_condattr_setclock supports CLOCK_MONOTONIC])], | |
5269150e | 445 | [AC_MSG_RESULT([no])], |
f2b508c1 | 446 | # Check existence of pthread_condattr_setclock if cross-compiling |
5269150e MW |
447 | [AC_MSG_RESULT([unknown]); |
448 | AC_CHECK_FUNCS(pthread_condattr_setclock, | |
a4037686 MW |
449 | [AC_DEFINE([HAVE_CONDATTR_CLOCK_MONOTONIC], [], |
450 | [have pthread_condattr_setclock()])] | |
5269150e | 451 | )] |
3d5818ec | 452 | ) |
f2b508c1 | 453 | # check if we actually are able to configure attributes on cond vars |
866dc013 | 454 | AC_CHECK_FUNCS(pthread_condattr_init) |
f2b508c1 | 455 | # instead of pthread_condattr_setclock Android has this function |
b2944d71 | 456 | AC_CHECK_FUNCS(pthread_cond_timedwait_monotonic) |
f2b508c1 | 457 | # check if we can cancel threads |
85202e87 | 458 | AC_CHECK_FUNCS(pthread_cancel) |
f2b508c1 | 459 | # check if native rwlocks are available |
f36143b0 | 460 | AC_CHECK_FUNCS(pthread_rwlock_init) |
f2b508c1 | 461 | # check if pthread spinlocks are available |
4185c644 | 462 | AC_CHECK_FUNCS(pthread_spin_init) |
f2b508c1 | 463 | # check if we have POSIX semaphore functions, including timed-wait |
907d3d0f | 464 | AC_CHECK_FUNCS(sem_timedwait) |
3d5818ec MW |
465 | LIBS=$saved_LIBS |
466 | ||
66f16d96 TB |
467 | AC_CHECK_FUNC( |
468 | [gettid], | |
a4037686 | 469 | [AC_DEFINE([HAVE_GETTID], [], [have gettid()])], |
66f16d96 | 470 | [AC_MSG_CHECKING([for SYS_gettid]) |
39a6c395 TB |
471 | AC_COMPILE_IFELSE( |
472 | [AC_LANG_PROGRAM( | |
473 | [[#define _GNU_SOURCE | |
474 | #include <unistd.h> | |
475 | #include <sys/syscall.h>]], | |
476 | [[int main() { | |
477 | return syscall(SYS_gettid);}]])], | |
a4037686 MW |
478 | [AC_MSG_RESULT([yes]); |
479 | AC_DEFINE([HAVE_GETTID], [], [have gettid()]) | |
480 | AC_DEFINE([HAVE_SYS_GETTID], [], [have syscall(SYS_gettid)])], | |
66f16d96 TB |
481 | [AC_MSG_RESULT([no])] |
482 | )] | |
c17f6f96 TB |
483 | ) |
484 | ||
53fcc70a | 485 | AC_CHECK_FUNCS(prctl mallinfo getpass closefrom getpwnam_r getgrnam_r getpwuid_r) |
4f990932 | 486 | |
a6390879 | 487 | AC_CHECK_HEADERS(sys/sockio.h glob.h) |
1e7b4b00 | 488 | AC_CHECK_HEADERS(net/pfkeyv2.h netipsec/ipsec.h netinet6/ipsec.h linux/udp.h) |
ae8ac58c TB |
489 | AC_CHECK_HEADERS(netinet/ip6.h, [], [], |
490 | [ | |
491 | #include <sys/types.h> | |
492 | #include <netinet/in.h> | |
493 | ]) | |
ea7e89c7 TB |
494 | |
495 | AC_CHECK_MEMBERS([struct sockaddr.sa_len], [], [], | |
496 | [ | |
497 | #include <sys/types.h> | |
498 | #include <sys/socket.h> | |
499 | ]) | |
500 | ||
501 | AC_CHECK_MEMBERS([struct sadb_x_policy.sadb_x_policy_priority], [], [], | |
502 | [ | |
503 | #include <sys/types.h> | |
504 | #ifdef HAVE_NET_PFKEYV2_H | |
505 | #include <net/pfkeyv2.h> | |
506 | #else | |
507 | #include <stdint.h> | |
508 | #include <linux/pfkeyv2.h> | |
509 | #endif | |
510 | ]) | |
e696757c | 511 | |
cb186f99 | 512 | AC_MSG_CHECKING([for in6addr_any]) |
39a6c395 TB |
513 | AC_COMPILE_IFELSE( |
514 | [AC_LANG_PROGRAM( | |
515 | [[#include <sys/types.h> | |
516 | #include <sys/socket.h> | |
517 | #include <netinet/in.h>]], | |
518 | [[struct in6_addr in6; | |
519 | in6 = in6addr_any;]])], | |
a4037686 MW |
520 | [AC_MSG_RESULT([yes]); |
521 | AC_DEFINE([HAVE_IN6ADDR_ANY], [], [have struct in6_addr in6addr_any])], | |
cb186f99 TB |
522 | [AC_MSG_RESULT([no])] |
523 | ) | |
524 | ||
525 | AC_MSG_CHECKING([for in6_pktinfo]) | |
39a6c395 TB |
526 | AC_COMPILE_IFELSE( |
527 | [AC_LANG_PROGRAM( | |
528 | [[#define _GNU_SOURCE | |
529 | #include <sys/types.h> | |
530 | #include <sys/socket.h> | |
531 | #include <netinet/in.h>]], | |
532 | [[struct in6_pktinfo pi; | |
533 | if (pi.ipi6_ifindex) | |
534 | { | |
535 | return 0; | |
536 | }]])], | |
a4037686 MW |
537 | [AC_MSG_RESULT([yes]); |
538 | AC_DEFINE([HAVE_IN6_PKTINFO], [], [have struct in6_pktinfo.ipi6_ifindex])], | |
cb186f99 TB |
539 | [AC_MSG_RESULT([no])] |
540 | ) | |
541 | ||
617e59b7 | 542 | AC_MSG_CHECKING([for IPSEC_MODE_BEET]) |
39a6c395 TB |
543 | AC_COMPILE_IFELSE( |
544 | [AC_LANG_PROGRAM( | |
545 | [[#include <sys/types.h> | |
546 | #ifdef HAVE_NETIPSEC_IPSEC_H | |
547 | #include <netipsec/ipsec.h> | |
548 | #elif defined(HAVE_NETINET6_IPSEC_H) | |
549 | #include <netinet6/ipsec.h> | |
550 | #else | |
551 | #include <stdint.h> | |
552 | #include <linux/ipsec.h> | |
553 | #endif]], | |
554 | [[int mode = IPSEC_MODE_BEET; | |
555 | return mode;]])], | |
a4037686 MW |
556 | [AC_MSG_RESULT([yes]); |
557 | AC_DEFINE([HAVE_IPSEC_MODE_BEET], [], [have IPSEC_MODE_BEET defined])], | |
617e59b7 TB |
558 | [AC_MSG_RESULT([no])] |
559 | ) | |
560 | ||
561 | AC_MSG_CHECKING([for IPSEC_DIR_FWD]) | |
39a6c395 TB |
562 | AC_COMPILE_IFELSE( |
563 | [AC_LANG_PROGRAM( | |
564 | [[#include <sys/types.h> | |
565 | #ifdef HAVE_NETIPSEC_IPSEC_H | |
566 | #include <netipsec/ipsec.h> | |
567 | #elif defined(HAVE_NETINET6_IPSEC_H) | |
568 | #include <netinet6/ipsec.h> | |
569 | #else | |
570 | #include <stdint.h> | |
571 | #include <linux/ipsec.h> | |
572 | #endif]], | |
573 | [[int dir = IPSEC_DIR_FWD; | |
574 | return dir;]])], | |
a4037686 MW |
575 | [AC_MSG_RESULT([yes]); |
576 | AC_DEFINE([HAVE_IPSEC_DIR_FWD], [], [have IPSEC_DIR_FWD defined])], | |
617e59b7 TB |
577 | [AC_MSG_RESULT([no])] |
578 | ) | |
579 | ||
439cb93c | 580 | AC_MSG_CHECKING([for RTA_TABLE]) |
39a6c395 TB |
581 | AC_COMPILE_IFELSE( |
582 | [AC_LANG_PROGRAM( | |
583 | [[#include <sys/socket.h> | |
584 | #include <linux/netlink.h> | |
585 | #include <linux/rtnetlink.h>]], | |
586 | [[int rta_type = RTA_TABLE; | |
587 | return rta_type;]])], | |
a4037686 MW |
588 | [AC_MSG_RESULT([yes]); |
589 | AC_DEFINE([HAVE_RTA_TABLE], [], [have netlink RTA_TABLE defined])], | |
439cb93c TB |
590 | [AC_MSG_RESULT([no])] |
591 | ) | |
592 | ||
efd0fe21 | 593 | AC_MSG_CHECKING([for gcc atomic operations]) |
39a6c395 TB |
594 | AC_RUN_IFELSE([AC_LANG_SOURCE( |
595 | [[ | |
596 | int main() { | |
597 | volatile int ref = 1; | |
598 | __sync_fetch_and_add (&ref, 1); | |
599 | __sync_sub_and_fetch (&ref, 1); | |
600 | /* Make sure test fails if operations are not supported */ | |
601 | __sync_val_compare_and_swap(&ref, 1, 0); | |
602 | return ref; | |
603 | } | |
604 | ]])], | |
605 | [AC_MSG_RESULT([yes]); | |
606 | AC_DEFINE([HAVE_GCC_ATOMIC_OPERATIONS], [], | |
a4037686 | 607 | [have GCC __sync_* atomic operations])], |
39a6c395 TB |
608 | [AC_MSG_RESULT([no])], |
609 | [AC_MSG_RESULT([no])] | |
610 | ) | |
efd0fe21 | 611 | |
f2b508c1 TB |
612 | # check for the new register_printf_specifier function with len argument, |
613 | # or the deprecated register_printf_function without | |
d25ce370 | 614 | AC_CHECK_FUNC( |
f6bbcec3 | 615 | [register_printf_specifier], |
a4037686 | 616 | [AC_DEFINE([HAVE_PRINTF_SPECIFIER], [], [have register_printf_specifier()])], |
f6bbcec3 | 617 | [AC_CHECK_FUNC( |
f6bbcec3 | 618 | [register_printf_function], |
a4037686 | 619 | [AC_DEFINE([HAVE_PRINTF_FUNCTION], [], [have register_printf_function()])], |
f6bbcec3 MW |
620 | [ |
621 | AC_MSG_NOTICE([printf does not support custom format specifiers!]) | |
622 | vstr=true | |
623 | ] | |
624 | )] | |
bf45d6dd TB |
625 | ) |
626 | ||
627 | if test x$vstr = xtrue; then | |
39a6c395 | 628 | AC_CHECK_LIB([vstr],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([Vstr string library not found])],[]) |
a4037686 | 629 | AC_DEFINE([USE_VSTR], [], [use vstring library for printf hooks]) |
bf45d6dd | 630 | fi |
d25ce370 | 631 | |
6b9290ff | 632 | if test x$gmp = xtrue; then |
3e35a6e7 | 633 | saved_LIBS=$LIBS |
39a6c395 | 634 | AC_CHECK_LIB([gmp],[main],[],[AC_MSG_ERROR([GNU Multi Precision library gmp not found])],[]) |
3e35a6e7 MW |
635 | AC_MSG_CHECKING([mpz_powm_sec]) |
636 | if test x$mpz_powm_sec = xyes; then | |
39a6c395 TB |
637 | AC_COMPILE_IFELSE( |
638 | [AC_LANG_PROGRAM( | |
639 | [[#include "gmp.h"]], | |
640 | [[void *x = mpz_powm_sec;]])], | |
a4037686 MW |
641 | [AC_MSG_RESULT([yes]); |
642 | AC_DEFINE([HAVE_MPZ_POWM_SEC], [], [have mpz_mown_sec()])], | |
643 | [AC_MSG_RESULT([no])] | |
3e35a6e7 MW |
644 | ) |
645 | else | |
646 | AC_MSG_RESULT([disabled]) | |
647 | fi | |
648 | LIBS=$saved_LIBS | |
6b9290ff | 649 | AC_MSG_CHECKING([gmp.h version >= 4.1.4]) |
39a6c395 TB |
650 | AC_COMPILE_IFELSE( |
651 | [AC_LANG_PROGRAM( | |
652 | [[#include "gmp.h"]], | |
653 | [[ | |
654 | #if (__GNU_MP_VERSION*100 + __GNU_MP_VERSION_MINOR*10 + __GNU_MP_VERSION_PATCHLEVEL) < 414 | |
655 | #error bad gmp | |
656 | #endif]])], | |
657 | [AC_MSG_RESULT([yes])], | |
658 | [AC_MSG_RESULT([no]); AC_MSG_ERROR([No usable gmp.h found!])] | |
6b9290ff | 659 | ) |
f2c2d395 | 660 | fi |
6b9290ff MW |
661 | |
662 | if test x$ldap = xtrue; then | |
39a6c395 TB |
663 | AC_CHECK_LIB([ldap],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([LDAP library ldap not found])],[]) |
664 | AC_CHECK_LIB([lber],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([LDAP library lber not found])],[]) | |
6b9290ff | 665 | AC_CHECK_HEADER([ldap.h],,[AC_MSG_ERROR([LDAP header ldap.h not found!])]) |
f2c2d395 MW |
666 | fi |
667 | ||
6b9290ff | 668 | if test x$curl = xtrue; then |
39a6c395 | 669 | AC_CHECK_LIB([curl],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([CURL library curl not found])],[]) |
6b9290ff MW |
670 | AC_CHECK_HEADER([curl/curl.h],,[AC_MSG_ERROR([CURL header curl/curl.h not found!])]) |
671 | fi | |
672 | ||
9f963a7c RG |
673 | if test x$unbound = xtrue; then |
674 | AC_HAVE_LIBRARY([ldns],[LIBS="$LIBS"],[AC_MSG_ERROR([UNBOUND library ldns not found])]) | |
675 | AC_CHECK_HEADER([ldns/ldns.h],,[AC_MSG_ERROR([UNBOUND header ldns/ldns.h not found!])]) | |
676 | AC_HAVE_LIBRARY([unbound],[LIBS="$LIBS"],[AC_MSG_ERROR([UNBOUND library libunbound not found])]) | |
677 | AC_CHECK_HEADER([unbound.h],,[AC_MSG_ERROR([UNBOUND header unbound.h not found!])]) | |
678 | fi | |
679 | ||
2ca52c80 MW |
680 | if test x$soup = xtrue; then |
681 | PKG_CHECK_MODULES(soup, [libsoup-2.4]) | |
682 | AC_SUBST(soup_CFLAGS) | |
683 | AC_SUBST(soup_LIBS) | |
684 | fi | |
685 | ||
6b9290ff | 686 | if test x$xml = xtrue; then |
a47486b5 | 687 | PKG_CHECK_MODULES(xml, [libxml-2.0]) |
f2d6355e MW |
688 | AC_SUBST(xml_CFLAGS) |
689 | AC_SUBST(xml_LIBS) | |
690 | fi | |
691 | ||
44566c22 | 692 | if test x$tss = xtrousers; then |
39a6c395 | 693 | AC_CHECK_LIB([tspi],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([TrouSerS library libtspi not found])],[]) |
005d981c | 694 | AC_CHECK_HEADER([trousers/tss.h],,[AC_MSG_ERROR([TrouSerS header trousers/tss.h not found!])]) |
6782bf37 | 695 | AC_DEFINE([TSS_TROUSERS], [], [use TrouSerS library libtspi as TSS implementation]) |
005d981c AS |
696 | fi |
697 | ||
a47486b5 MW |
698 | if test x$dumm = xtrue; then |
699 | PKG_CHECK_MODULES(gtk, [gtk+-2.0 vte]) | |
700 | AC_SUBST(gtk_CFLAGS) | |
701 | AC_SUBST(gtk_LIBS) | |
d2e9cbc9 TB |
702 | AC_CHECK_PROGS(RUBY, ruby) |
703 | AC_MSG_CHECKING([for Ruby header files]) | |
704 | if test -n "$RUBY"; then | |
5057df5b TB |
705 | RUBYINCLUDE= |
706 | RUBYDIR=`($RUBY -r rbconfig -e 'print RbConfig::CONFIG[["rubyhdrdir"]] || ""') 2>/dev/null` | |
707 | if test -n "$RUBYDIR" -a -r "$RUBYDIR/ruby.h"; then | |
708 | RUBYARCH=`($RUBY -r rbconfig -e 'print RbConfig::CONFIG[["arch"]] || ""') 2>/dev/null` | |
709 | if test -n "$RUBYARCH"; then | |
710 | AC_MSG_RESULT([$RUBYDIR]) | |
711 | RUBYINCLUDE="-I$RUBYDIR -I$RUBYDIR/$RUBYARCH" | |
d2e9cbc9 | 712 | fi |
d2e9cbc9 | 713 | else |
5057df5b TB |
714 | RUBYDIR=`($RUBY -r rbconfig -e 'print RbConfig::CONFIG[["archdir"]] || ""') 2>/dev/null` |
715 | if test -n "$RUBYDIR" -a -r "$RUBYDIR/ruby.h"; then | |
716 | AC_MSG_RESULT([$RUBYDIR]) | |
717 | RUBYINCLUDE="-I$RUBYDIR" | |
718 | fi | |
719 | fi | |
720 | if test -z "$RUBYINCLUDE"; then | |
721 | AC_MSG_ERROR([ruby.h not found]) | |
d2e9cbc9 | 722 | fi |
5057df5b | 723 | AC_SUBST(RUBYINCLUDE) |
d2e9cbc9 TB |
724 | else |
725 | AC_MSG_ERROR([don't know how to run ruby]) | |
726 | fi | |
afabe7b0 TB |
727 | AC_MSG_CHECKING([for libruby]) |
728 | saved_LIBS=$LIBS | |
729 | LIBS=`($RUBY -r rbconfig -e 'print RbConfig::CONFIG[["LIBRUBYARG_SHARED"]] || ""') 2>/dev/null` | |
730 | AC_TRY_LINK_FUNC(ruby_init, | |
731 | [AC_MSG_RESULT([$LIBS]); RUBYLIB=$LIBS], | |
732 | [AC_MSG_ERROR([not found])]) | |
733 | AC_SUBST(RUBYLIB) | |
d972975d | 734 | AC_CHECK_FUNCS(rb_errinfo) |
afabe7b0 | 735 | LIBS=$saved_LIBS |
a47486b5 MW |
736 | fi |
737 | ||
6b9290ff | 738 | if test x$fast = xtrue; then |
39a6c395 TB |
739 | AC_CHECK_LIB([neo_cgi],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([ClearSilver library neo_cgi not found!])],[]) |
740 | AC_CHECK_LIB([neo_utl],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([ClearSilver library neo_utl not found!])],[]) | |
f9a0f556 MW |
741 | AC_MSG_CHECKING([ClearSilver requires zlib]) |
742 | saved_CFLAGS=$CFLAGS | |
743 | saved_LIBS=$LIBS | |
744 | LIBS="-lneo_cgi -lneo_cs -lneo_utl" | |
745 | CFLAGS="-I/usr/include/ClearSilver" | |
39a6c395 TB |
746 | AC_LINK_IFELSE( |
747 | [AC_LANG_PROGRAM( | |
748 | [[#include <ClearSilver.h>]], | |
749 | [[NEOERR *err = cgi_display(NULL, NULL);]])], | |
f9a0f556 MW |
750 | [AC_MSG_RESULT([no]); clearsilver_LIBS="$LIBS"], |
751 | [AC_MSG_RESULT([yes]); clearsilver_LIBS="$LIBS -lz"] | |
752 | ) | |
753 | AC_SUBST(clearsilver_LIBS) | |
754 | LIBS=$saved_LIBS | |
755 | CFLAGS=$saved_CFLAGS | |
f2b508c1 TB |
756 | # autoconf does not like CamelCase!? How to fix this? |
757 | # AC_CHECK_HEADER([ClearSilver/ClearSilver.h],,[AC_MSG_ERROR([ClearSilver header file ClearSilver/ClearSilver.h not found!])]) | |
8b3b4a24 | 758 | |
39a6c395 | 759 | AC_CHECK_LIB([fcgi],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([FastCGI library fcgi not found!])],[]) |
6b9290ff | 760 | AC_CHECK_HEADER([fcgiapp.h],,[AC_MSG_ERROR([FastCGI header file fcgiapp.h not found!])]) |
a84fb01b MW |
761 | fi |
762 | ||
6b9290ff | 763 | if test x$mysql = xtrue; then |
84074347 MW |
764 | AC_PATH_PROG([MYSQLCONFIG], [mysql_config], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) |
765 | if test x$MYSQLCONFIG = x; then | |
766 | AC_MSG_ERROR([mysql_config not found!]) | |
767 | fi | |
768 | AC_SUBST(MYSQLLIB, `$MYSQLCONFIG --libs_r`) | |
769 | AC_SUBST(MYSQLCFLAG, `$MYSQLCONFIG --cflags`) | |
6b9290ff | 770 | fi |
f2c2d395 | 771 | |
f8277a83 | 772 | if test x$sqlite = xtrue; then |
39a6c395 | 773 | AC_CHECK_LIB([sqlite3],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([SQLite library sqlite3 not found])],[]) |
6b9290ff | 774 | AC_CHECK_HEADER([sqlite3.h],,[AC_MSG_ERROR([SQLite header sqlite3.h not found!])]) |
f8277a83 | 775 | AC_MSG_CHECKING([sqlite3_prepare_v2]) |
39a6c395 TB |
776 | AC_COMPILE_IFELSE( |
777 | [AC_LANG_PROGRAM( | |
778 | [[#include <sqlite3.h>]], | |
779 | [[void *test = sqlite3_prepare_v2;]])], | |
780 | [AC_MSG_RESULT([yes]); | |
781 | AC_DEFINE([HAVE_SQLITE3_PREPARE_V2], [], [have sqlite3_prepare_v2()])], | |
782 | [AC_MSG_RESULT([no])] | |
783 | ) | |
7da767f7 | 784 | AC_MSG_CHECKING([sqlite3.h version >= 3.3.1]) |
39a6c395 TB |
785 | AC_COMPILE_IFELSE( |
786 | [AC_LANG_PROGRAM( | |
787 | [[#include <sqlite3.h>]], | |
788 | [[ | |
789 | #if SQLITE_VERSION_NUMBER < 3003001 | |
790 | #error bad sqlite | |
791 | #endif]])], | |
792 | [AC_MSG_RESULT([yes])], | |
793 | [AC_MSG_RESULT([no]); AC_MSG_ERROR([SQLite version >= 3.3.1 required!])] | |
794 | ) | |
6b9290ff | 795 | fi |
f2c2d395 | 796 | |
17353034 | 797 | if test x$openssl = xtrue; then |
39a6c395 | 798 | AC_CHECK_LIB([crypto],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([OpenSSL crypto library not found])],[]) |
17353034 TB |
799 | AC_CHECK_HEADER([openssl/evp.h],,[AC_MSG_ERROR([OpenSSL header openssl/evp.h not found!])]) |
800 | fi | |
801 | ||
4977018c | 802 | if test x$gcrypt = xtrue; then |
39a6c395 | 803 | AC_CHECK_LIB([gcrypt],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([gcrypt library not found])],[-lgpg-error]) |
1d39663f | 804 | AC_CHECK_HEADER([gcrypt.h],,[AC_MSG_ERROR([gcrypt header gcrypt.h not found!])]) |
62d6da67 | 805 | AC_MSG_CHECKING([gcrypt CAMELLIA cipher]) |
39a6c395 TB |
806 | AC_COMPILE_IFELSE( |
807 | [AC_LANG_PROGRAM( | |
808 | [[#include <gcrypt.h>]], | |
809 | [[enum gcry_cipher_algos alg = GCRY_CIPHER_CAMELLIA128;]])], | |
a4037686 MW |
810 | [AC_MSG_RESULT([yes]); |
811 | AC_DEFINE([HAVE_GCRY_CIPHER_CAMELLIA], [], [have GCRY_CIPHER_CAMELLIA128])], | |
62d6da67 MW |
812 | [AC_MSG_RESULT([no])] |
813 | ) | |
4977018c MW |
814 | fi |
815 | ||
61c46386 | 816 | if test x$uci = xtrue; then |
39a6c395 | 817 | AC_CHECK_LIB([uci],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([UCI library libuci not found])],[]) |
61c46386 MW |
818 | AC_CHECK_HEADER([uci.h],,[AC_MSG_ERROR([UCI header uci.h not found!])]) |
819 | fi | |
820 | ||
9804fcce | 821 | if test x$android_dns = xtrue; then |
39a6c395 | 822 | AC_CHECK_LIB([cutils],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([Android library libcutils not found])],[]) |
55699f03 | 823 | AC_CHECK_HEADER([cutils/properties.h],,[AC_MSG_ERROR([Android header cutils/properties.h not found!])]) |
f2b508c1 TB |
824 | # we have to force the use of libdl here because the autodetection |
825 | # above does not work correctly when cross-compiling for android. | |
c711687c TB |
826 | DLLIB="-ldl" |
827 | AC_SUBST(DLLIB) | |
55699f03 MW |
828 | fi |
829 | ||
2bce8141 | 830 | if test x$maemo = xtrue; then |
8464e25a TB |
831 | PKG_CHECK_MODULES(maemo, [glib-2.0 gthread-2.0 libosso osso-af-settings]) |
832 | AC_SUBST(maemo_CFLAGS) | |
833 | AC_SUBST(maemo_LIBS) | |
2bce8141 TB |
834 | dbusservicedir="/usr/share/dbus-1/system-services" |
835 | AC_SUBST(dbusservicedir) | |
836 | fi | |
837 | ||
80dca77a DS |
838 | if test x$eap_sim_pcsc = xtrue; then |
839 | PKG_CHECK_MODULES(pcsclite, [libpcsclite]) | |
840 | AC_SUBST(pcsclite_CFLAGS) | |
841 | AC_SUBST(pcsclite_LIBS) | |
842 | fi | |
843 | ||
6dbce9c8 | 844 | if test x$nm = xtrue; then |
89d236f0 | 845 | PKG_CHECK_EXISTS([libnm-glib], |
0aa90701 TB |
846 | [PKG_CHECK_MODULES(nm, [NetworkManager gthread-2.0 libnm-util libnm-glib libnm-glib-vpn])], |
847 | [PKG_CHECK_MODULES(nm, [NetworkManager gthread-2.0 libnm_util libnm_glib libnm_glib_vpn])] | |
89d236f0 | 848 | ) |
6dbce9c8 MW |
849 | AC_SUBST(nm_CFLAGS) |
850 | AC_SUBST(nm_LIBS) | |
851 | fi | |
852 | ||
b9e49163 | 853 | if test x$xauth_pam = xtrue; then |
39a6c395 | 854 | AC_CHECK_LIB([pam],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([PAM library not found])],[]) |
1caa265c MW |
855 | AC_CHECK_HEADER([security/pam_appl.h],,[AC_MSG_ERROR([PAM header security/pam_appl.h not found!])]) |
856 | fi | |
857 | ||
946be4d3 TB |
858 | if test x$capabilities = xnative; then |
859 | AC_MSG_NOTICE([Usage of the native Linux capabilities interface is deprecated, use libcap instead]) | |
f2b508c1 TB |
860 | # Linux requires the following for capset(), Android does not have it, |
861 | # but defines capset() in unistd.h instead. | |
946be4d3 TB |
862 | AC_CHECK_HEADERS([sys/capability.h]) |
863 | AC_CHECK_FUNC(capset,,[AC_MSG_ERROR([capset() not found!])]) | |
a4037686 | 864 | AC_DEFINE([CAPABILITIES_NATIVE], [], [have native linux capset()]) |
946be4d3 TB |
865 | fi |
866 | ||
eb3e2705 | 867 | if test x$capabilities = xlibcap; then |
39a6c395 | 868 | AC_CHECK_LIB([cap],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([libcap library not found])],[]) |
946be4d3 | 869 | AC_CHECK_HEADER([sys/capability.h], |
a4037686 | 870 | [AC_DEFINE([HAVE_SYS_CAPABILITY_H], [], [have sys/capability.h])], |
946be4d3 | 871 | [AC_MSG_ERROR([libcap header sys/capability.h not found!])]) |
a4037686 | 872 | AC_DEFINE([CAPABILITIES_LIBCAP], [], [have libpcap library]) |
eb3e2705 MW |
873 | fi |
874 | ||
e4e6a77a MW |
875 | if test x$integrity_test = xtrue; then |
876 | AC_MSG_CHECKING([for dladdr()]) | |
39a6c395 TB |
877 | AC_COMPILE_IFELSE( |
878 | [AC_LANG_PROGRAM( | |
879 | [[#define _GNU_SOURCE | |
880 | #include <dlfcn.h>]], | |
881 | [[Dl_info info; dladdr(main, &info);]])], | |
882 | [AC_MSG_RESULT([yes])], | |
883 | [AC_MSG_RESULT([no]); | |
e4e6a77a MW |
884 | AC_MSG_ERROR([dladdr() not supported, required by integrity-test!])] |
885 | ) | |
886 | AC_MSG_CHECKING([for dl_iterate_phdr()]) | |
39a6c395 TB |
887 | AC_COMPILE_IFELSE( |
888 | [AC_LANG_PROGRAM( | |
889 | [[#define _GNU_SOURCE | |
890 | #include <link.h>]], | |
891 | [[dl_iterate_phdr((void*)0, (void*)0);]])], | |
892 | [AC_MSG_RESULT([yes])], | |
893 | [AC_MSG_RESULT([no]); | |
e4e6a77a MW |
894 | AC_MSG_ERROR([dl_iterate_phdr() not supported, required by integrity-test!])] |
895 | ) | |
896 | fi | |
897 | ||
4c6c9346 | 898 | if test x$bfd_backtraces = xtrue; then |
39a6c395 | 899 | AC_CHECK_LIB([bfd],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([binutils libbfd not found!])],[]) |
4c6c9346 MW |
900 | AC_CHECK_HEADER([bfd.h],[AC_DEFINE([HAVE_BFD_H],,[have binutils bfd.h])], |
901 | [AC_MSG_ERROR([binutils bfd.h header not found!])]) | |
902 | BFDLIB="-lbfd" | |
903 | AC_SUBST(BFDLIB) | |
904 | fi | |
905 | ||
83714577 MW |
906 | if test x$unwind_backtraces = xtrue; then |
907 | AC_CHECK_LIB([unwind],[main],[LIBS="$LIBS"],[AC_MSG_ERROR([libunwind not found!])],[]) | |
908 | AC_CHECK_HEADER([libunwind.h],[AC_DEFINE([HAVE_LIBUNWIND_H],,[have libunwind.h])], | |
909 | [AC_MSG_ERROR([libunwind.h header not found!])]) | |
910 | UNWINDLIB="-lunwind" | |
911 | AC_SUBST(UNWINDLIB) | |
912 | fi | |
913 | ||
b188f231 | 914 | AM_CONDITIONAL(USE_DEV_HEADERS, [test "x$dev_headers" != xno]) |
bbe5b505 MW |
915 | if test x$dev_headers = xyes; then |
916 | dev_headers="$includedir/strongswan" | |
917 | fi | |
b188f231 MW |
918 | AC_SUBST(dev_headers) |
919 | ||
7300eb29 MW |
920 | CFLAGS="$CFLAGS -include `pwd`/config.h" |
921 | ||
559fe48c RB |
922 | if test x$tkm = xtrue; then |
923 | AC_PATH_PROG([GPRBUILD], [gprbuild], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
924 | fi | |
925 | ||
0aa5a466 AKR |
926 | if test x$unit_tests = xtrue; then |
927 | PKG_CHECK_MODULES(CHECK, [check >= 0.9.4]) | |
928 | AC_SUBST(CHECK_CFLAGS) | |
929 | AC_SUBST(CHECK_LIBS) | |
930 | fi | |
931 | ||
1f14b4a1 TB |
932 | if test x$coverage = xtrue; then |
933 | AC_PATH_PROG([LCOV], [lcov], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
934 | if test x$LCOV = x; then | |
935 | AC_MSG_ERROR([lcov not found]) | |
936 | fi | |
937 | AC_PATH_PROG([GENHTML], [genhtml], [], [$PATH:/bin:/usr/bin:/usr/local/bin]) | |
938 | if test x$GENHTML = x; then | |
939 | AC_MSG_ERROR([genhtml not found]) | |
940 | fi | |
941 | ||
942 | COVERAGE_CFLAGS="-fprofile-arcs -ftest-coverage" | |
943 | COVERAGE_LDFLAGS="-fprofile-arcs" | |
944 | AC_SUBST(COVERAGE_CFLAGS) | |
945 | AC_SUBST(COVERAGE_LDFLAGS) | |
946 | ||
947 | AC_MSG_NOTICE([coverage enabled, adding "-g -O0" to CFLAGS]) | |
948 | CFLAGS="${CFLAGS} -g -O0" | |
949 | fi | |
950 | ||
f2b508c1 TB |
951 | # =============================================== |
952 | # collect plugin list for strongSwan components | |
953 | # =============================================== | |
1ba62b55 | 954 | |
9e2c88b9 MW |
955 | m4_include(m4/macros/add-plugin.m4) |
956 | ||
8f018151 | 957 | # plugin lists for all components |
94b48e07 | 958 | charon_plugins= |
f3a682c1 | 959 | starter_plugins= |
8f018151 | 960 | pool_plugins= |
60212277 | 961 | attest_plugins= |
8f018151 MW |
962 | openac_plugins= |
963 | scepclient_plugins= | |
964 | pki_plugins= | |
965 | scripts_plugins= | |
966 | manager_plugins= | |
967 | medsrv_plugins= | |
1c7a733e | 968 | nm_plugins= |
1fed10be | 969 | cmd_plugins= |
8f018151 | 970 | |
123a84d3 | 971 | # location specific lists for checksumming, |
e8f65c5c | 972 | # for src/libcharon, src/libhydra, src/libstrongswan and src/libtnccs |
123a84d3 | 973 | c_plugins= |
123a84d3 MW |
974 | h_plugins= |
975 | s_plugins= | |
e8f65c5c | 976 | t_plugins= |
123a84d3 | 977 | |
fff4b74d | 978 | ADD_PLUGIN([test-vectors], [s charon openac scepclient pki]) |
1fed10be MW |
979 | ADD_PLUGIN([curl], [s charon scepclient scripts nm cmd]) |
980 | ADD_PLUGIN([soup], [s charon scripts nm cmd]) | |
9f963a7c | 981 | ADD_PLUGIN([unbound], [s charon scripts]) |
1fed10be | 982 | ADD_PLUGIN([ldap], [s charon scepclient scripts nm cmd]) |
fff4b74d TB |
983 | ADD_PLUGIN([mysql], [s charon pool manager medsrv attest]) |
984 | ADD_PLUGIN([sqlite], [s charon pool manager medsrv attest]) | |
1fed10be MW |
985 | ADD_PLUGIN([pkcs11], [s charon pki nm cmd]) |
986 | ADD_PLUGIN([aes], [s charon openac scepclient pki scripts nm cmd]) | |
987 | ADD_PLUGIN([des], [s charon openac scepclient pki scripts nm cmd]) | |
988 | ADD_PLUGIN([blowfish], [s charon openac scepclient pki scripts nm cmd]) | |
9d4fc867 | 989 | ADD_PLUGIN([rc2], [s charon openac scepclient pki scripts nm cmd]) |
1fed10be MW |
990 | ADD_PLUGIN([sha1], [s charon openac scepclient pki scripts medsrv attest nm cmd]) |
991 | ADD_PLUGIN([sha2], [s charon openac scepclient pki scripts medsrv attest nm cmd]) | |
992 | ADD_PLUGIN([md4], [s charon openac manager scepclient pki nm cmd]) | |
993 | ADD_PLUGIN([md5], [s charon openac scepclient pki scripts attest nm cmd]) | |
994 | ADD_PLUGIN([rdrand], [s charon openac scepclient pki scripts medsrv attest nm cmd]) | |
995 | ADD_PLUGIN([random], [s charon openac scepclient pki scripts medsrv attest nm cmd]) | |
996 | ADD_PLUGIN([nonce], [s charon nm cmd]) | |
997 | ADD_PLUGIN([x509], [s charon openac scepclient pki scripts attest nm cmd]) | |
998 | ADD_PLUGIN([revocation], [s charon nm cmd]) | |
999 | ADD_PLUGIN([constraints], [s charon nm cmd]) | |
8372b8fc | 1000 | ADD_PLUGIN([pubkey], [s charon cmd]) |
1fed10be | 1001 | ADD_PLUGIN([pkcs1], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) |
b7aa6b78 | 1002 | ADD_PLUGIN([pkcs7], [s charon scepclient pki scripts nm cmd]) |
1fed10be | 1003 | ADD_PLUGIN([pkcs8], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) |
02116fdc | 1004 | ADD_PLUGIN([pkcs12], [s charon scepclient pki scripts cmd]) |
fff4b74d TB |
1005 | ADD_PLUGIN([pgp], [s charon]) |
1006 | ADD_PLUGIN([dnskey], [s charon]) | |
e07e489d | 1007 | ADD_PLUGIN([sshkey], [s charon nm cmd]) |
a77bbc3b | 1008 | ADD_PLUGIN([ipseckey], [c charon]) |
1fed10be | 1009 | ADD_PLUGIN([pem], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) |
94b48e07 | 1010 | ADD_PLUGIN([padlock], [s charon]) |
1fed10be MW |
1011 | ADD_PLUGIN([openssl], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) |
1012 | ADD_PLUGIN([gcrypt], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) | |
1013 | ADD_PLUGIN([af-alg], [s charon openac scepclient pki scripts medsrv attest nm cmd]) | |
1014 | ADD_PLUGIN([fips-prf], [s charon nm cmd]) | |
1015 | ADD_PLUGIN([gmp], [s charon openac scepclient pki scripts manager medsrv attest nm cmd]) | |
1016 | ADD_PLUGIN([agent], [s charon nm cmd]) | |
7b8edabd | 1017 | ADD_PLUGIN([keychain], [s charon cmd]) |
1fed10be MW |
1018 | ADD_PLUGIN([xcbc], [s charon nm cmd]) |
1019 | ADD_PLUGIN([cmac], [s charon nm cmd]) | |
1020 | ADD_PLUGIN([hmac], [s charon scripts nm cmd]) | |
1021 | ADD_PLUGIN([ctr], [s charon scripts nm cmd]) | |
1022 | ADD_PLUGIN([ccm], [s charon scripts nm cmd]) | |
1023 | ADD_PLUGIN([gcm], [s charon scripts nm cmd]) | |
fff4b74d TB |
1024 | ADD_PLUGIN([attr], [h charon]) |
1025 | ADD_PLUGIN([attr-sql], [h charon]) | |
94b48e07 | 1026 | ADD_PLUGIN([load-tester], [c charon]) |
279e0d42 | 1027 | ADD_PLUGIN([kernel-libipsec], [c charon cmd]) |
1fed10be MW |
1028 | ADD_PLUGIN([kernel-pfkey], [h charon starter nm cmd]) |
1029 | ADD_PLUGIN([kernel-pfroute], [h charon starter nm cmd]) | |
fff4b74d | 1030 | ADD_PLUGIN([kernel-klips], [h charon starter]) |
1fed10be MW |
1031 | ADD_PLUGIN([kernel-netlink], [h charon starter nm cmd]) |
1032 | ADD_PLUGIN([resolve], [h charon cmd]) | |
1033 | ADD_PLUGIN([socket-default], [c charon nm cmd]) | |
f0749552 | 1034 | ADD_PLUGIN([socket-dynamic], [c charon cmd]) |
94b48e07 TB |
1035 | ADD_PLUGIN([farp], [c charon]) |
1036 | ADD_PLUGIN([stroke], [c charon]) | |
1037 | ADD_PLUGIN([smp], [c charon]) | |
1038 | ADD_PLUGIN([sql], [c charon]) | |
1039 | ADD_PLUGIN([updown], [c charon]) | |
1fed10be | 1040 | ADD_PLUGIN([eap-identity], [c charon nm cmd]) |
94b48e07 TB |
1041 | ADD_PLUGIN([eap-sim], [c charon]) |
1042 | ADD_PLUGIN([eap-sim-file], [c charon]) | |
1043 | ADD_PLUGIN([eap-sim-pcsc], [c charon]) | |
1044 | ADD_PLUGIN([eap-aka], [c charon]) | |
1045 | ADD_PLUGIN([eap-aka-3gpp2], [c charon]) | |
1046 | ADD_PLUGIN([eap-simaka-sql], [c charon]) | |
1047 | ADD_PLUGIN([eap-simaka-pseudonym], [c charon]) | |
1048 | ADD_PLUGIN([eap-simaka-reauth], [c charon]) | |
1fed10be MW |
1049 | ADD_PLUGIN([eap-md5], [c charon nm cmd]) |
1050 | ADD_PLUGIN([eap-gtc], [c charon nm cmd]) | |
1051 | ADD_PLUGIN([eap-mschapv2], [c charon nm cmd]) | |
700ff5de | 1052 | ADD_PLUGIN([eap-dynamic], [c charon]) |
94b48e07 | 1053 | ADD_PLUGIN([eap-radius], [c charon]) |
1fed10be MW |
1054 | ADD_PLUGIN([eap-tls], [c charon nm cmd]) |
1055 | ADD_PLUGIN([eap-ttls], [c charon nm cmd]) | |
1056 | ADD_PLUGIN([eap-peap], [c charon nm cmd]) | |
94b48e07 | 1057 | ADD_PLUGIN([eap-tnc], [c charon]) |
1fed10be | 1058 | ADD_PLUGIN([xauth-generic], [c charon cmd]) |
94b48e07 | 1059 | ADD_PLUGIN([xauth-eap], [c charon]) |
b9e49163 | 1060 | ADD_PLUGIN([xauth-pam], [c charon]) |
e4013bb9 | 1061 | ADD_PLUGIN([xauth-noauth], [c charon]) |
45e2be23 | 1062 | ADD_PLUGIN([tnc-ifmap], [c charon]) |
94b48e07 | 1063 | ADD_PLUGIN([tnc-pdp], [c charon]) |
e8f65c5c | 1064 | ADD_PLUGIN([tnc-imc], [t charon]) |
94b48e07 | 1065 | ADD_PLUGIN([tnc-imv], [c charon]) |
e8f65c5c AS |
1066 | ADD_PLUGIN([tnc-tnccs], [t charon]) |
1067 | ADD_PLUGIN([tnccs-20], [t charon]) | |
1068 | ADD_PLUGIN([tnccs-11], [t charon]) | |
1069 | ADD_PLUGIN([tnccs-dynamic], [t charon]) | |
94b48e07 TB |
1070 | ADD_PLUGIN([medsrv], [c charon]) |
1071 | ADD_PLUGIN([medcli], [c charon]) | |
94b48e07 | 1072 | ADD_PLUGIN([dhcp], [c charon]) |
45dcf4df | 1073 | ADD_PLUGIN([osx-attr], [c charon cmd]) |
9804fcce | 1074 | ADD_PLUGIN([android-dns], [c charon]) |
162621ed | 1075 | ADD_PLUGIN([android-log], [c charon]) |
94b48e07 TB |
1076 | ADD_PLUGIN([ha], [c charon]) |
1077 | ADD_PLUGIN([whitelist], [c charon]) | |
e0d7c1ed | 1078 | ADD_PLUGIN([lookip], [c charon]) |
0aaf5ccf | 1079 | ADD_PLUGIN([error-notify], [c charon]) |
94b48e07 | 1080 | ADD_PLUGIN([certexpire], [c charon]) |
0ed31e72 | 1081 | ADD_PLUGIN([systime-fix], [c charon]) |
94b48e07 TB |
1082 | ADD_PLUGIN([led], [c charon]) |
1083 | ADD_PLUGIN([duplicheck], [c charon]) | |
1084 | ADD_PLUGIN([coupling], [c charon]) | |
1085 | ADD_PLUGIN([radattr], [c charon]) | |
1086 | ADD_PLUGIN([maemo], [c charon]) | |
1087 | ADD_PLUGIN([uci], [c charon]) | |
1088 | ADD_PLUGIN([addrblock], [c charon]) | |
5ff012f7 | 1089 | ADD_PLUGIN([unity], [c charon]) |
94b48e07 TB |
1090 | ADD_PLUGIN([unit-tester], [c charon]) |
1091 | ||
1092 | AC_SUBST(charon_plugins) | |
f3a682c1 | 1093 | AC_SUBST(starter_plugins) |
8f018151 | 1094 | AC_SUBST(pool_plugins) |
60212277 | 1095 | AC_SUBST(attest_plugins) |
8f018151 MW |
1096 | AC_SUBST(openac_plugins) |
1097 | AC_SUBST(scepclient_plugins) | |
1098 | AC_SUBST(pki_plugins) | |
1099 | AC_SUBST(scripts_plugins) | |
1100 | AC_SUBST(manager_plugins) | |
1101 | AC_SUBST(medsrv_plugins) | |
1c7a733e | 1102 | AC_SUBST(nm_plugins) |
1fed10be | 1103 | AC_SUBST(cmd_plugins) |
1ba62b55 | 1104 | |
123a84d3 | 1105 | AC_SUBST(c_plugins) |
123a84d3 MW |
1106 | AC_SUBST(h_plugins) |
1107 | AC_SUBST(s_plugins) | |
e8f65c5c | 1108 | AC_SUBST(t_plugins) |
123a84d3 | 1109 | |
f2b508c1 TB |
1110 | # ====================== |
1111 | # set Makefile.am vars | |
1112 | # ====================== | |
f2c2d395 | 1113 | |
f2b508c1 TB |
1114 | # libstrongswan plugins |
1115 | # ----------------------- | |
81811a9d | 1116 | AM_CONDITIONAL(USE_TEST_VECTORS, test x$test_vectors = xtrue) |
6b9290ff | 1117 | AM_CONDITIONAL(USE_CURL, test x$curl = xtrue) |
9f963a7c | 1118 | AM_CONDITIONAL(USE_UNBOUND, test x$unbound = xtrue) |
2ca52c80 | 1119 | AM_CONDITIONAL(USE_SOUP, test x$soup = xtrue) |
6b9290ff MW |
1120 | AM_CONDITIONAL(USE_LDAP, test x$ldap = xtrue) |
1121 | AM_CONDITIONAL(USE_AES, test x$aes = xtrue) | |
1122 | AM_CONDITIONAL(USE_DES, test x$des = xtrue) | |
d36ae9e3 | 1123 | AM_CONDITIONAL(USE_BLOWFISH, test x$blowfish = xtrue) |
9d4fc867 | 1124 | AM_CONDITIONAL(USE_RC2, test x$rc2 = xtrue) |
1e0d1ae2 | 1125 | AM_CONDITIONAL(USE_MD4, test x$md4 = xtrue) |
6b9290ff MW |
1126 | AM_CONDITIONAL(USE_MD5, test x$md5 = xtrue) |
1127 | AM_CONDITIONAL(USE_SHA1, test x$sha1 = xtrue) | |
1128 | AM_CONDITIONAL(USE_SHA2, test x$sha2 = xtrue) | |
1129 | AM_CONDITIONAL(USE_FIPS_PRF, test x$fips_prf = xtrue) | |
1130 | AM_CONDITIONAL(USE_GMP, test x$gmp = xtrue) | |
ed8dc6f1 | 1131 | AM_CONDITIONAL(USE_RDRAND, test x$rdrand = xtrue) |
6a365f07 | 1132 | AM_CONDITIONAL(USE_RANDOM, test x$random = xtrue) |
04024b5d | 1133 | AM_CONDITIONAL(USE_NONCE, test x$nonce = xtrue) |
6b9290ff | 1134 | AM_CONDITIONAL(USE_X509, test x$x509 = xtrue) |
c2e5cee4 | 1135 | AM_CONDITIONAL(USE_REVOCATION, test x$revocation = xtrue) |
01d30381 | 1136 | AM_CONDITIONAL(USE_CONSTRAINTS, test x$constraints = xtrue) |
affd7a90 | 1137 | AM_CONDITIONAL(USE_PUBKEY, test x$pubkey = xtrue) |
1e0f6937 | 1138 | AM_CONDITIONAL(USE_PKCS1, test x$pkcs1 = xtrue) |
bd20f040 | 1139 | AM_CONDITIONAL(USE_PKCS7, test x$pkcs7 = xtrue) |
5ec525c1 | 1140 | AM_CONDITIONAL(USE_PKCS8, test x$pkcs8 = xtrue) |
feef6373 | 1141 | AM_CONDITIONAL(USE_PKCS12, test x$pkcs12 = xtrue) |
9493dd2c | 1142 | AM_CONDITIONAL(USE_PGP, test x$pgp = xtrue) |
5ef478aa | 1143 | AM_CONDITIONAL(USE_DNSKEY, test x$dnskey = xtrue) |
584d656b | 1144 | AM_CONDITIONAL(USE_SSHKEY, test x$sshkey = xtrue) |
160f4c22 | 1145 | AM_CONDITIONAL(USE_PEM, test x$pem = xtrue) |
6b9290ff | 1146 | AM_CONDITIONAL(USE_HMAC, test x$hmac = xtrue) |
c0d39c20 | 1147 | AM_CONDITIONAL(USE_CMAC, test x$cmac = xtrue) |
27d04e05 | 1148 | AM_CONDITIONAL(USE_XCBC, test x$xcbc = xtrue) |
6b9290ff MW |
1149 | AM_CONDITIONAL(USE_MYSQL, test x$mysql = xtrue) |
1150 | AM_CONDITIONAL(USE_SQLITE, test x$sqlite = xtrue) | |
1ba62b55 MW |
1151 | AM_CONDITIONAL(USE_PADLOCK, test x$padlock = xtrue) |
1152 | AM_CONDITIONAL(USE_OPENSSL, test x$openssl = xtrue) | |
4977018c | 1153 | AM_CONDITIONAL(USE_GCRYPT, test x$gcrypt = xtrue) |
21c95463 | 1154 | AM_CONDITIONAL(USE_AGENT, test x$agent = xtrue) |
7b8edabd | 1155 | AM_CONDITIONAL(USE_KEYCHAIN, test x$keychain = xtrue) |
6e862e21 | 1156 | AM_CONDITIONAL(USE_PKCS11, test x$pkcs11 = xtrue) |
272f0e1a | 1157 | AM_CONDITIONAL(USE_CTR, test x$ctr = xtrue) |
80a93a13 | 1158 | AM_CONDITIONAL(USE_CCM, test x$ccm = xtrue) |
1a649810 | 1159 | AM_CONDITIONAL(USE_GCM, test x$gcm = xtrue) |
71c87e34 | 1160 | AM_CONDITIONAL(USE_AF_ALG, test x$af_alg = xtrue) |
1ba62b55 | 1161 | |
f2b508c1 TB |
1162 | # charon plugins |
1163 | # ---------------- | |
6b9290ff | 1164 | AM_CONDITIONAL(USE_STROKE, test x$stroke = xtrue) |
5b7ec6d4 | 1165 | AM_CONDITIONAL(USE_MEDSRV, test x$medsrv = xtrue) |
782db7ed | 1166 | AM_CONDITIONAL(USE_MEDCLI, test x$medcli = xtrue) |
61c46386 | 1167 | AM_CONDITIONAL(USE_UCI, test x$uci = xtrue) |
45dcf4df | 1168 | AM_CONDITIONAL(USE_OSX_ATTR, test x$osx_attr = xtrue) |
9804fcce | 1169 | AM_CONDITIONAL(USE_ANDROID_DNS, test x$android_dns = xtrue) |
162621ed | 1170 | AM_CONDITIONAL(USE_ANDROID_LOG, test x$android_log = xtrue) |
f79161e8 | 1171 | AM_CONDITIONAL(USE_MAEMO, test x$maemo = xtrue) |
6b9290ff MW |
1172 | AM_CONDITIONAL(USE_SMP, test x$smp = xtrue) |
1173 | AM_CONDITIONAL(USE_SQL, test x$sql = xtrue) | |
a77bbc3b | 1174 | AM_CONDITIONAL(USE_IPSECKEY, test x$ipseckey = xtrue) |
ad3af574 | 1175 | AM_CONDITIONAL(USE_UPDOWN, test x$updown = xtrue) |
beaa048e | 1176 | AM_CONDITIONAL(USE_DHCP, test x$dhcp = xtrue) |
61706107 | 1177 | AM_CONDITIONAL(USE_UNIT_TESTS, test x$unit_tester = xtrue) |
b76b867c | 1178 | AM_CONDITIONAL(USE_LOAD_TESTER, test x$load_tester = xtrue) |
e67f5136 | 1179 | AM_CONDITIONAL(USE_HA, test x$ha = xtrue) |
279e0d42 | 1180 | AM_CONDITIONAL(USE_KERNEL_LIBIPSEC, test x$kernel_libipsec = xtrue) |
5e603aba | 1181 | AM_CONDITIONAL(USE_WHITELIST, test x$whitelist = xtrue) |
e0d7c1ed | 1182 | AM_CONDITIONAL(USE_LOOKIP, test x$lookip = xtrue) |
0aaf5ccf | 1183 | AM_CONDITIONAL(USE_ERROR_NOTIFY, test x$error_notify = xtrue) |
ba2201ed | 1184 | AM_CONDITIONAL(USE_CERTEXPIRE, test x$certexpire = xtrue) |
0ed31e72 | 1185 | AM_CONDITIONAL(USE_SYSTIME_FIX, test x$systime_fix = xtrue) |
30cd31fb | 1186 | AM_CONDITIONAL(USE_LED, test x$led = xtrue) |
3e74ebbe | 1187 | AM_CONDITIONAL(USE_DUPLICHECK, test x$duplicheck = xtrue) |
007c4708 | 1188 | AM_CONDITIONAL(USE_COUPLING, test x$coupling = xtrue) |
caf4b88e | 1189 | AM_CONDITIONAL(USE_RADATTR, test x$radattr = xtrue) |
6b9290ff | 1190 | AM_CONDITIONAL(USE_EAP_SIM, test x$eap_sim = xtrue) |
79a87846 | 1191 | AM_CONDITIONAL(USE_EAP_SIM_FILE, test x$eap_sim_file = xtrue) |
80dca77a | 1192 | AM_CONDITIONAL(USE_EAP_SIM_PCSC, test x$eap_sim_pcsc = xtrue) |
d2c35874 | 1193 | AM_CONDITIONAL(USE_EAP_SIMAKA_SQL, test x$eap_simaka_sql = xtrue) |
edcb2dd3 MW |
1194 | AM_CONDITIONAL(USE_EAP_SIMAKA_PSEUDONYM, test x$eap_simaka_pseudonym = xtrue) |
1195 | AM_CONDITIONAL(USE_EAP_SIMAKA_REAUTH, test x$eap_simaka_reauth = xtrue) | |
6b9290ff MW |
1196 | AM_CONDITIONAL(USE_EAP_IDENTITY, test x$eap_identity = xtrue) |
1197 | AM_CONDITIONAL(USE_EAP_MD5, test x$eap_md5 = xtrue) | |
1caa265c | 1198 | AM_CONDITIONAL(USE_EAP_GTC, test x$eap_gtc = xtrue) |
6b9290ff | 1199 | AM_CONDITIONAL(USE_EAP_AKA, test x$eap_aka = xtrue) |
47208157 | 1200 | AM_CONDITIONAL(USE_EAP_AKA_3GPP2, test x$eap_aka_3gpp2 = xtrue) |
f98cdf7a | 1201 | AM_CONDITIONAL(USE_EAP_MSCHAPV2, test x$eap_mschapv2 = xtrue) |
21079538 | 1202 | AM_CONDITIONAL(USE_EAP_TLS, test x$eap_tls = xtrue) |
26eb9b2d | 1203 | AM_CONDITIONAL(USE_EAP_TTLS, test x$eap_ttls = xtrue) |
1be296df | 1204 | AM_CONDITIONAL(USE_EAP_PEAP, test x$eap_peap = xtrue) |
d93e2e54 | 1205 | AM_CONDITIONAL(USE_EAP_TNC, test x$eap_tnc = xtrue) |
700ff5de | 1206 | AM_CONDITIONAL(USE_EAP_DYNAMIC, test x$eap_dynamic = xtrue) |
4a6b84a9 | 1207 | AM_CONDITIONAL(USE_EAP_RADIUS, test x$eap_radius = xtrue) |
3d44d735 | 1208 | AM_CONDITIONAL(USE_XAUTH_GENERIC, test x$xauth_generic = xtrue) |
85fc1eb6 | 1209 | AM_CONDITIONAL(USE_XAUTH_EAP, test x$xauth_eap = xtrue) |
b9e49163 | 1210 | AM_CONDITIONAL(USE_XAUTH_PAM, test x$xauth_pam = xtrue) |
e4013bb9 | 1211 | AM_CONDITIONAL(USE_XAUTH_NOAUTH, test x$xauth_noauth = xtrue) |
45e2be23 | 1212 | AM_CONDITIONAL(USE_TNC_IFMAP, test x$tnc_ifmap = xtrue) |
70fd2d1a | 1213 | AM_CONDITIONAL(USE_TNC_PDP, test x$tnc_pdp = xtrue) |
8dcc56dc AS |
1214 | AM_CONDITIONAL(USE_TNC_IMC, test x$tnc_imc = xtrue) |
1215 | AM_CONDITIONAL(USE_TNC_IMV, test x$tnc_imv = xtrue) | |
b08505da | 1216 | AM_CONDITIONAL(USE_TNC_TNCCS, test x$tnc_tnccs = xtrue) |
4e8e74fc | 1217 | AM_CONDITIONAL(USE_TNCCS_11, test x$tnccs_11 = xtrue) |
6d0e9cf0 | 1218 | AM_CONDITIONAL(USE_TNCCS_20, test x$tnccs_20 = xtrue) |
f652995b | 1219 | AM_CONDITIONAL(USE_TNCCS_DYNAMIC, test x$tnccs_dynamic = xtrue) |
510f37ab AS |
1220 | AM_CONDITIONAL(USE_IMC_TEST, test x$imc_test = xtrue) |
1221 | AM_CONDITIONAL(USE_IMV_TEST, test x$imv_test = xtrue) | |
d9cdab92 AS |
1222 | AM_CONDITIONAL(USE_IMC_SCANNER, test x$imc_scanner = xtrue) |
1223 | AM_CONDITIONAL(USE_IMV_SCANNER, test x$imv_scanner = xtrue) | |
e9f47ee2 AS |
1224 | AM_CONDITIONAL(USE_IMC_OS, test x$imc_os = xtrue) |
1225 | AM_CONDITIONAL(USE_IMV_OS, test x$imv_os = xtrue) | |
4a492a8d AS |
1226 | AM_CONDITIONAL(USE_IMC_ATTESTATION, test x$imc_attestation = xtrue) |
1227 | AM_CONDITIONAL(USE_IMV_ATTESTATION, test x$imv_attestation = xtrue) | |
dab05604 | 1228 | AM_CONDITIONAL(USE_SOCKET_DEFAULT, test x$socket_default = xtrue) |
9ed1bb48 | 1229 | AM_CONDITIONAL(USE_SOCKET_DYNAMIC, test x$socket_dynamic = xtrue) |
0d7b48a3 | 1230 | AM_CONDITIONAL(USE_FARP, test x$farp = xtrue) |
1c8c9246 | 1231 | AM_CONDITIONAL(USE_ADDRBLOCK, test x$addrblock = xtrue) |
5ff012f7 | 1232 | AM_CONDITIONAL(USE_UNITY, test x$unity = xtrue) |
1ba62b55 | 1233 | |
f2b508c1 TB |
1234 | # hydra plugins |
1235 | # --------------- | |
26ec52a4 | 1236 | AM_CONDITIONAL(USE_ATTR, test x$attr = xtrue) |
613fb0b4 | 1237 | AM_CONDITIONAL(USE_ATTR_SQL, test x$attr_sql = xtrue) |
062a6022 TB |
1238 | AM_CONDITIONAL(USE_KERNEL_KLIPS, test x$kernel_klips = xtrue) |
1239 | AM_CONDITIONAL(USE_KERNEL_NETLINK, test x$kernel_netlink = xtrue) | |
1240 | AM_CONDITIONAL(USE_KERNEL_PFKEY, test x$kernel_pfkey = xtrue) | |
1241 | AM_CONDITIONAL(USE_KERNEL_PFROUTE, test x$kernel_pfroute = xtrue) | |
26ec52a4 AS |
1242 | AM_CONDITIONAL(USE_RESOLVE, test x$resolve = xtrue) |
1243 | ||
f2b508c1 TB |
1244 | # other options |
1245 | # --------------- | |
1ba62b55 | 1246 | AM_CONDITIONAL(USE_LEAK_DETECTIVE, test x$leak_detective = xtrue) |
02140125 | 1247 | AM_CONDITIONAL(USE_LOCK_PROFILER, test x$lock_profiler = xtrue) |
6b9290ff MW |
1248 | AM_CONDITIONAL(USE_DUMM, test x$dumm = xtrue) |
1249 | AM_CONDITIONAL(USE_FAST, test x$fast = xtrue) | |
1250 | AM_CONDITIONAL(USE_MANAGER, test x$manager = xtrue) | |
e20b7921 | 1251 | AM_CONDITIONAL(USE_ME, test x$mediation = xtrue) |
6b9290ff | 1252 | AM_CONDITIONAL(USE_INTEGRITY_TEST, test x$integrity_test = xtrue) |
3de510ca | 1253 | AM_CONDITIONAL(USE_LOAD_WARNING, test x$load_warning = xtrue) |
ccdd3a4c | 1254 | AM_CONDITIONAL(USE_IKEV1, test x$ikev1 = xtrue) |
e51a28fd | 1255 | AM_CONDITIONAL(USE_IKEV2, test x$ikev2 = xtrue) |
6905f794 | 1256 | AM_CONDITIONAL(USE_THREADS, test x$threads = xtrue) |
d52c3779 | 1257 | AM_CONDITIONAL(USE_ADNS, test x$adns = xtrue) |
6b9290ff | 1258 | AM_CONDITIONAL(USE_CHARON, test x$charon = xtrue) |
1c7a733e | 1259 | AM_CONDITIONAL(USE_NM, test x$nm = xtrue) |
6b9290ff | 1260 | AM_CONDITIONAL(USE_TOOLS, test x$tools = xtrue) |
cf00cffe | 1261 | AM_CONDITIONAL(USE_SCRIPTS, test x$scripts = xtrue) |
e78ec86d | 1262 | AM_CONDITIONAL(USE_CONFTEST, test x$conftest = xtrue) |
1fed10be MW |
1263 | AM_CONDITIONAL(USE_LIBSTRONGSWAN, test x$charon = xtrue -o x$tools = xtrue -o x$conftest = xtrue -o x$fast = xtrue -o x$imcv = xtrue -o x$nm = xtrue -o x$tkm = xtrue -o x$cmd = xtrue) |
1264 | AM_CONDITIONAL(USE_LIBHYDRA, test x$charon = xtrue -o x$nm = xtrue -o x$tkm = xtrue -o x$cmd = xtrue) | |
1265 | AM_CONDITIONAL(USE_LIBCHARON, test x$charon = xtrue -o x$conftest = xtrue -o x$nm = xtrue -o x$tkm = xtrue -o x$cmd = xtrue) | |
b70139fb | 1266 | AM_CONDITIONAL(USE_LIBIPSEC, test x$libipsec = xtrue) |
f8b1b327 | 1267 | AM_CONDITIONAL(USE_LIBTNCIF, test x$tnc_tnccs = xtrue -o x$imcv = xtrue) |
b08505da | 1268 | AM_CONDITIONAL(USE_LIBTNCCS, test x$tnc_tnccs = xtrue) |
18d56a18 | 1269 | AM_CONDITIONAL(USE_LIBPTTLS, test x$tnc_tnccs = xtrue) |
fff4b74d TB |
1270 | AM_CONDITIONAL(USE_FILE_CONFIG, test x$stroke = xtrue) |
1271 | AM_CONDITIONAL(USE_IPSEC_SCRIPT, test x$stroke = xtrue -o x$tools = xtrue -o x$conftest = xtrue) | |
b77e493b | 1272 | AM_CONDITIONAL(USE_LIBCAP, test x$capabilities = xlibcap) |
d25ce370 | 1273 | AM_CONDITIONAL(USE_VSTR, test x$vstr = xtrue) |
f8330d03 | 1274 | AM_CONDITIONAL(USE_SIMAKA, test x$simaka = xtrue) |
0f82a470 | 1275 | AM_CONDITIONAL(USE_TLS, test x$tls = xtrue) |
f0f94e2c | 1276 | AM_CONDITIONAL(USE_RADIUS, test x$radius = xtrue) |
510f37ab | 1277 | AM_CONDITIONAL(USE_IMCV, test x$imcv = xtrue) |
3ed943c3 | 1278 | AM_CONDITIONAL(USE_PTS, test x$pts = xtrue) |
44566c22 | 1279 | AM_CONDITIONAL(USE_TROUSERS, test x$tss = xtrousers) |
3372ad14 | 1280 | AM_CONDITIONAL(MONOLITHIC, test x$monolithic = xtrue) |
d0f01a58 | 1281 | AM_CONDITIONAL(USE_SILENT_RULES, test x$enable_silent_rules = xyes) |
0aa5a466 | 1282 | AM_CONDITIONAL(UNITTESTS, test x$unit_tests = xtrue) |
1f14b4a1 | 1283 | AM_CONDITIONAL(COVERAGE, test x$coverage = xtrue) |
559fe48c | 1284 | AM_CONDITIONAL(USE_TKM, test x$tkm = xtrue) |
1fed10be | 1285 | AM_CONDITIONAL(USE_CMD, test x$cmd = xtrue) |
f2c2d395 | 1286 | |
f2b508c1 TB |
1287 | # ======================== |
1288 | # set global definitions | |
1289 | # ======================== | |
9e72d3bc | 1290 | |
a7f79ee9 | 1291 | if test x$mediation = xtrue; then |
a4037686 | 1292 | AC_DEFINE([ME], [], [mediation extension support]) |
9e72d3bc | 1293 | fi |
946be4d3 | 1294 | if test x$capabilities = xlibcap -o x$capabilities = xnative; then |
a4037686 | 1295 | AC_DEFINE([CAPABILITIES], [], [capability dropping support]) |
eb3e2705 | 1296 | fi |
3372ad14 | 1297 | if test x$monolithic = xtrue; then |
a4037686 | 1298 | AC_DEFINE([MONOLITHIC], [], [monolithic build embedding plugins]) |
3372ad14 | 1299 | fi |
ccdd3a4c | 1300 | if test x$ikev1 = xtrue; then |
a4037686 | 1301 | AC_DEFINE([USE_IKEV1], [], [support for IKEv1 protocol]) |
ccdd3a4c | 1302 | fi |
e51a28fd | 1303 | if test x$ikev2 = xtrue; then |
a4037686 | 1304 | AC_DEFINE([USE_IKEV2], [], [support for IKEv2 protocol]) |
e51a28fd | 1305 | fi |
9e72d3bc | 1306 | |
f2b508c1 TB |
1307 | # ================= |
1308 | # build Makefiles | |
1309 | # ================= | |
f2c2d395 | 1310 | |
39a6c395 | 1311 | AC_CONFIG_FILES([ |
f2c2d395 | 1312 | Makefile |
0a1233e6 | 1313 | man/Makefile |
fc16b361 MV |
1314 | init/Makefile |
1315 | init/systemd/Makefile | |
f2c2d395 | 1316 | src/Makefile |
04a7b6d8 | 1317 | src/include/Makefile |
f2c2d395 | 1318 | src/libstrongswan/Makefile |
552cc11b | 1319 | src/libstrongswan/plugins/aes/Makefile |
c0d39c20 | 1320 | src/libstrongswan/plugins/cmac/Makefile |
552cc11b | 1321 | src/libstrongswan/plugins/des/Makefile |
d36ae9e3 | 1322 | src/libstrongswan/plugins/blowfish/Makefile |
9d4fc867 | 1323 | src/libstrongswan/plugins/rc2/Makefile |
1e0d1ae2 | 1324 | src/libstrongswan/plugins/md4/Makefile |
552cc11b MW |
1325 | src/libstrongswan/plugins/md5/Makefile |
1326 | src/libstrongswan/plugins/sha1/Makefile | |
1327 | src/libstrongswan/plugins/sha2/Makefile | |
1328 | src/libstrongswan/plugins/fips_prf/Makefile | |
1329 | src/libstrongswan/plugins/gmp/Makefile | |
ed8dc6f1 | 1330 | src/libstrongswan/plugins/rdrand/Makefile |
6a365f07 | 1331 | src/libstrongswan/plugins/random/Makefile |
04024b5d | 1332 | src/libstrongswan/plugins/nonce/Makefile |
552cc11b | 1333 | src/libstrongswan/plugins/hmac/Makefile |
27d04e05 | 1334 | src/libstrongswan/plugins/xcbc/Makefile |
552cc11b | 1335 | src/libstrongswan/plugins/x509/Makefile |
c2e5cee4 | 1336 | src/libstrongswan/plugins/revocation/Makefile |
01d30381 | 1337 | src/libstrongswan/plugins/constraints/Makefile |
affd7a90 | 1338 | src/libstrongswan/plugins/pubkey/Makefile |
1e0f6937 | 1339 | src/libstrongswan/plugins/pkcs1/Makefile |
bd20f040 | 1340 | src/libstrongswan/plugins/pkcs7/Makefile |
5ec525c1 | 1341 | src/libstrongswan/plugins/pkcs8/Makefile |
feef6373 | 1342 | src/libstrongswan/plugins/pkcs12/Makefile |
9493dd2c | 1343 | src/libstrongswan/plugins/pgp/Makefile |
5ef478aa | 1344 | src/libstrongswan/plugins/dnskey/Makefile |
584d656b | 1345 | src/libstrongswan/plugins/sshkey/Makefile |
160f4c22 | 1346 | src/libstrongswan/plugins/pem/Makefile |
552cc11b | 1347 | src/libstrongswan/plugins/curl/Makefile |
9f963a7c | 1348 | src/libstrongswan/plugins/unbound/Makefile |
2ca52c80 | 1349 | src/libstrongswan/plugins/soup/Makefile |
552cc11b MW |
1350 | src/libstrongswan/plugins/ldap/Makefile |
1351 | src/libstrongswan/plugins/mysql/Makefile | |
1352 | src/libstrongswan/plugins/sqlite/Makefile | |
36d62fac | 1353 | src/libstrongswan/plugins/padlock/Makefile |
17353034 | 1354 | src/libstrongswan/plugins/openssl/Makefile |
4977018c | 1355 | src/libstrongswan/plugins/gcrypt/Makefile |
21c95463 | 1356 | src/libstrongswan/plugins/agent/Makefile |
7b8edabd | 1357 | src/libstrongswan/plugins/keychain/Makefile |
6e862e21 | 1358 | src/libstrongswan/plugins/pkcs11/Makefile |
272f0e1a | 1359 | src/libstrongswan/plugins/ctr/Makefile |
80a93a13 | 1360 | src/libstrongswan/plugins/ccm/Makefile |
1a649810 | 1361 | src/libstrongswan/plugins/gcm/Makefile |
71c87e34 | 1362 | src/libstrongswan/plugins/af_alg/Makefile |
81811a9d | 1363 | src/libstrongswan/plugins/test_vectors/Makefile |
156dcbc1 | 1364 | src/libstrongswan/tests/Makefile |
0bf68cbf | 1365 | src/libhydra/Makefile |
a5ec3025 | 1366 | src/libhydra/plugins/attr/Makefile |
75dc0192 | 1367 | src/libhydra/plugins/attr_sql/Makefile |
062a6022 TB |
1368 | src/libhydra/plugins/kernel_klips/Makefile |
1369 | src/libhydra/plugins/kernel_netlink/Makefile | |
1370 | src/libhydra/plugins/kernel_pfkey/Makefile | |
1371 | src/libhydra/plugins/kernel_pfroute/Makefile | |
9a0333fa | 1372 | src/libhydra/plugins/resolve/Makefile |
b70139fb | 1373 | src/libipsec/Makefile |
f8330d03 | 1374 | src/libsimaka/Makefile |
0f82a470 | 1375 | src/libtls/Makefile |
f0f94e2c | 1376 | src/libradius/Makefile |
7c4d4d20 | 1377 | src/libtncif/Makefile |
f0fa002f | 1378 | src/libtnccs/Makefile |
e8f65c5c AS |
1379 | src/libtnccs/plugins/tnc_tnccs/Makefile |
1380 | src/libtnccs/plugins/tnc_imc/Makefile | |
1381 | src/libtnccs/plugins/tnccs_11/Makefile | |
1382 | src/libtnccs/plugins/tnccs_20/Makefile | |
1383 | src/libtnccs/plugins/tnccs_dynamic/Makefile | |
18d56a18 | 1384 | src/libpttls/Makefile |
3ed943c3 | 1385 | src/libpts/Makefile |
b448e3ec AS |
1386 | src/libpts/plugins/imc_attestation/Makefile |
1387 | src/libpts/plugins/imv_attestation/Makefile | |
510f37ab | 1388 | src/libimcv/Makefile |
71ad7798 AS |
1389 | src/libimcv/plugins/imc_test/Makefile |
1390 | src/libimcv/plugins/imv_test/Makefile | |
d9cdab92 AS |
1391 | src/libimcv/plugins/imc_scanner/Makefile |
1392 | src/libimcv/plugins/imv_scanner/Makefile | |
e9f47ee2 AS |
1393 | src/libimcv/plugins/imc_os/Makefile |
1394 | src/libimcv/plugins/imv_os/Makefile | |
f2c2d395 | 1395 | src/charon/Makefile |
1c7a733e | 1396 | src/charon-nm/Makefile |
559fe48c | 1397 | src/charon-tkm/Makefile |
1fed10be | 1398 | src/charon-cmd/Makefile |
bd3f8ea3 TB |
1399 | src/libcharon/Makefile |
1400 | src/libcharon/plugins/eap_aka/Makefile | |
1401 | src/libcharon/plugins/eap_aka_3gpp2/Makefile | |
700ff5de | 1402 | src/libcharon/plugins/eap_dynamic/Makefile |
bd3f8ea3 TB |
1403 | src/libcharon/plugins/eap_identity/Makefile |
1404 | src/libcharon/plugins/eap_md5/Makefile | |
1405 | src/libcharon/plugins/eap_gtc/Makefile | |
1406 | src/libcharon/plugins/eap_sim/Makefile | |
1407 | src/libcharon/plugins/eap_sim_file/Makefile | |
80dca77a | 1408 | src/libcharon/plugins/eap_sim_pcsc/Makefile |
d2c35874 | 1409 | src/libcharon/plugins/eap_simaka_sql/Makefile |
bd3f8ea3 TB |
1410 | src/libcharon/plugins/eap_simaka_pseudonym/Makefile |
1411 | src/libcharon/plugins/eap_simaka_reauth/Makefile | |
1412 | src/libcharon/plugins/eap_mschapv2/Makefile | |
21079538 | 1413 | src/libcharon/plugins/eap_tls/Makefile |
26eb9b2d | 1414 | src/libcharon/plugins/eap_ttls/Makefile |
1be296df | 1415 | src/libcharon/plugins/eap_peap/Makefile |
d93e2e54 | 1416 | src/libcharon/plugins/eap_tnc/Makefile |
bd3f8ea3 | 1417 | src/libcharon/plugins/eap_radius/Makefile |
3d44d735 | 1418 | src/libcharon/plugins/xauth_generic/Makefile |
85fc1eb6 | 1419 | src/libcharon/plugins/xauth_eap/Makefile |
b9e49163 | 1420 | src/libcharon/plugins/xauth_pam/Makefile |
e4013bb9 | 1421 | src/libcharon/plugins/xauth_noauth/Makefile |
45e2be23 | 1422 | src/libcharon/plugins/tnc_ifmap/Makefile |
70fd2d1a | 1423 | src/libcharon/plugins/tnc_pdp/Makefile |
8dcc56dc | 1424 | src/libcharon/plugins/tnc_imv/Makefile |
bd3f8ea3 | 1425 | src/libcharon/plugins/socket_default/Makefile |
bd3f8ea3 | 1426 | src/libcharon/plugins/socket_dynamic/Makefile |
0d7b48a3 | 1427 | src/libcharon/plugins/farp/Makefile |
bd3f8ea3 TB |
1428 | src/libcharon/plugins/smp/Makefile |
1429 | src/libcharon/plugins/sql/Makefile | |
a77bbc3b | 1430 | src/libcharon/plugins/ipseckey/Makefile |
bd3f8ea3 TB |
1431 | src/libcharon/plugins/medsrv/Makefile |
1432 | src/libcharon/plugins/medcli/Makefile | |
1c8c9246 | 1433 | src/libcharon/plugins/addrblock/Makefile |
5ff012f7 | 1434 | src/libcharon/plugins/unity/Makefile |
bd3f8ea3 | 1435 | src/libcharon/plugins/uci/Makefile |
d8748966 | 1436 | src/libcharon/plugins/ha/Makefile |
279e0d42 | 1437 | src/libcharon/plugins/kernel_libipsec/Makefile |
5e603aba | 1438 | src/libcharon/plugins/whitelist/Makefile |
e0d7c1ed | 1439 | src/libcharon/plugins/lookip/Makefile |
0aaf5ccf | 1440 | src/libcharon/plugins/error_notify/Makefile |
ba2201ed | 1441 | src/libcharon/plugins/certexpire/Makefile |
0ed31e72 | 1442 | src/libcharon/plugins/systime_fix/Makefile |
30cd31fb | 1443 | src/libcharon/plugins/led/Makefile |
3e74ebbe | 1444 | src/libcharon/plugins/duplicheck/Makefile |
007c4708 | 1445 | src/libcharon/plugins/coupling/Makefile |
caf4b88e | 1446 | src/libcharon/plugins/radattr/Makefile |
45dcf4df | 1447 | src/libcharon/plugins/osx_attr/Makefile |
9804fcce | 1448 | src/libcharon/plugins/android_dns/Makefile |
162621ed | 1449 | src/libcharon/plugins/android_log/Makefile |
f79161e8 | 1450 | src/libcharon/plugins/maemo/Makefile |
bd3f8ea3 TB |
1451 | src/libcharon/plugins/stroke/Makefile |
1452 | src/libcharon/plugins/updown/Makefile | |
beaa048e | 1453 | src/libcharon/plugins/dhcp/Makefile |
bd3f8ea3 TB |
1454 | src/libcharon/plugins/unit_tester/Makefile |
1455 | src/libcharon/plugins/load_tester/Makefile | |
f2c2d395 MW |
1456 | src/stroke/Makefile |
1457 | src/ipsec/Makefile | |
1458 | src/starter/Makefile | |
1459 | src/_updown/Makefile | |
1460 | src/_updown_espmark/Makefile | |
1461 | src/_copyright/Makefile | |
1462 | src/openac/Makefile | |
1463 | src/scepclient/Makefile | |
7c577c8e | 1464 | src/pki/Makefile |
f2d6355e | 1465 | src/dumm/Makefile |
2d9ce480 | 1466 | src/dumm/ext/extconf.rb |
552cc11b | 1467 | src/libfast/Makefile |
b8c7453a | 1468 | src/manager/Makefile |
9529fb68 | 1469 | src/medsrv/Makefile |
67a7bb02 | 1470 | src/checksum/Makefile |
e78ec86d | 1471 | src/conftest/Makefile |
180a2f26 | 1472 | src/pt-tls-client/Makefile |
39b7780d | 1473 | scripts/Makefile |
9ee1111d | 1474 | testing/Makefile |
39a6c395 TB |
1475 | ]) |
1476 | AC_OUTPUT | |
2ccdc19e TB |
1477 | |
1478 | # ======================== | |
1479 | # report enabled plugins | |
1480 | # ======================== | |
1481 | ||
1482 | AC_MSG_RESULT([]) | |
1483 | AC_MSG_RESULT([ strongSwan will be built with the following plugins]) | |
1484 | AC_MSG_RESULT([-----------------------------------------------------]) | |
1485 | ||
1486 | AC_MSG_RESULT([libstrongswan:$s_plugins]) | |
1487 | AC_MSG_RESULT([libcharon: $c_plugins]) | |
1488 | AC_MSG_RESULT([libhydra: $h_plugins]) | |
e8f65c5c | 1489 | AC_MSG_RESULT([libtnccs: $t_plugins]) |
2ccdc19e | 1490 | AC_MSG_RESULT([]) |