mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-24 21:50:53 +00:00 
			
		
		
		
	BuildSystem: Check for alternate openssl packages
OpenSSL is one of those packages that often have alternatives
with later versions.  For instance, CentOS/EL 7 has an
openssl package at version 1.0.2 but there's an openssl11
package from the epel repository that has 1.1.1.  This gets
installed to /usr/include/openssl11 and /usr/lib64/openssl11.
Unfortunately, the existing --with-ssl and --with-crypto
./configure options expect to point to a source tree and
don't work in this situation.  Also unfortunately, the
checks in ./configure don't use pkg-config.
In order to make this work with the existing situation, you'd
have to run...
./configure --with-ssl=/usr/lib64/openssl11 \
    --with-crypto=/usr/lib64/openssl11 \
    CFLAGS=-I/usr/include/openssl11
BUT...  those options don't get passed down to bundled pjproject
so when you run make, you have to include the CFLAGS again
which is a big pain.
Oh...  To make matters worse, although you can specify
PJPROJECT_CONFIGURE_OPTS on the ./configure command line,
they don't get saved so if you do a make clean, which will
force a re-configure of bundled pjproject, those options
don't get used.
So...
* In configure.ac... Since pkg-config is installed by install_prereq
  anyway, we now use it to check for the system openssl >= 1.1.0.
  If that works, great.  If not, we check for the openssl11
  package. If that works, great.  If not, we fall back to just
  checking for any openssl.  If pkg-config isn't installed for some
  reason, or --with-ssl=<dir> or --with-crypto=<dir> were specified
  on the ./configure command line, we fall back to the existing
  logic that uses AST_EXT_LIB_CHECK().
* The whole OpenSSL check process has been moved up before
  THIRD_PARTY_CONFIGURE(), which does the initial pjproject
  bundled configure, is run.  This way the results of the above
  checks, which may result in new include or library directories,
  is included.
* Although not strictly needed for openssl, We now save the value of
  PJPROJECT_CONFIGURE_OPTS in the makeopts file so it can be used
  again if a re-configure is triggered.
ASTERISK-29693
Change-Id: I341ab7603e6b156aa15a66f43675ac5029d5fbde
			
			
This commit is contained in:
		
							
								
								
									
										61
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										61
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -313,6 +313,8 @@ AC_PATH_PROG([LDCONFIG], [ldconfig], :) | ||||
| AC_PATH_PROG([SHA1SUM], [sha1sum], $ac_aux_dir/build_tools/sha1sum-sh) | ||||
| AC_PATH_PROG([OPENSSL], [openssl], :) | ||||
|  | ||||
| PKG_PROG_PKG_CONFIG() | ||||
|  | ||||
| AC_CACHE_CHECK([for bison that supports parse-param], [ac_cv_path_BISON2], [ | ||||
| 	if test "x$BISON" != "x:" ; then | ||||
| 		# Create a temporary directory $tmp in $TMPDIR (default /tmp). | ||||
| @@ -458,6 +460,52 @@ if test "${with_pjproject}" == "no" || test "${with_pjproject}" == "n" ; then | ||||
| 	PJPROJECT_BUNDLED=no | ||||
| fi | ||||
|  | ||||
| # | ||||
| # OpenSSL stuff has to be done here because we want to pass | ||||
| # any resulting CFLAGS and LDFLAGS to the bundled pjproject | ||||
| # configure done in THIRD_PARTY_CONFIGURE() | ||||
| # | ||||
| AST_EXT_LIB_SETUP([CRYPTO], [OpenSSL Cryptography], [crypto]) | ||||
| AST_EXT_LIB_SETUP([OPENSSL], [OpenSSL Secure Sockets Layer], [ssl]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([OPENSSL_BIO_METHOD], [OpenSSL BIO Method Support], [CRYPTO], [crypto]) | ||||
|  | ||||
| # If neither --without-ssl (PBX_OPENSSL=-1) nor --without-crypto (PBX_CRYPTO=-1) | ||||
| # and there were no directories atdded to --with-ssl and --with-crypto, and | ||||
| # pkg-config is installed (which is should be by install_prereq). | ||||
| if test "x$PKG_CONFIG" != "x" -a $PBX_OPENSSL -ge 0 -a $PBX_CRYPTO -ge 0 -a "x$OPENSSL_DIR" == "x" ; then | ||||
| 	AC_MSG_NOTICE(checking OPENSSL with pkg-config) | ||||
| 	AC_MSG_NOTICE(checking whether system openssl > 1.1.0) | ||||
| 	AST_PKG_CONFIG_CHECK([OPENSSL], [openssl >= 1.1.0]) | ||||
| 	if test $PBX_OPENSSL -eq 0 ; then | ||||
| 		AC_MSG_NOTICE(checking whether alternate openssl11 is installed) | ||||
| 		AST_PKG_CONFIG_CHECK([OPENSSL], [openssl11]) | ||||
| 	fi | ||||
| 	if test $PBX_OPENSSL -eq 1 ; then | ||||
| 		AC_DEFINE([HAVE_OPENSSL_BIO_METHOD], 1) | ||||
| 		PBX_OPENSSL_BIO_METHOD=1 | ||||
| 	else | ||||
| 		AC_MSG_NOTICE(checking fallback system openssl) | ||||
| 		AST_PKG_CONFIG_CHECK([OPENSSL], [openssl]) | ||||
| 	fi | ||||
|  | ||||
| 	if test $PBX_OPENSSL -eq 1; then | ||||
| 		AC_DEFINE([HAVE_CRYPTO], 1) | ||||
| 		PBX_CRYPTO=1 | ||||
| 	fi | ||||
| else | ||||
| 	AC_MSG_NOTICE(Checking OPENSSL without pkg-config) | ||||
| 	AST_EXT_LIB_CHECK([CRYPTO], [crypto], [AES_encrypt], [openssl/aes.h]) | ||||
| 	if test "$PBX_CRYPTO" = "1"; | ||||
| 	then | ||||
| 		AST_EXT_LIB_CHECK([OPENSSL], [ssl], [SSL_connect], [openssl/ssl.h], [-lcrypto]) | ||||
| 		AST_EXT_LIB_CHECK([OPENSSL_BIO_METHOD], [ssl], [BIO_meth_new], [openssl/ssl.h], [-lcrypto]) | ||||
| 	fi | ||||
| fi | ||||
| if test $PBX_OPENSSL -eq 0 ; then | ||||
| 	AC_MSG_WARN(OpenSSL does not seem to be installed) | ||||
| fi | ||||
|  | ||||
|  | ||||
| THIRD_PARTY_CONFIGURE() | ||||
|  | ||||
| # AST_EXT_LIB_SETUP is used to tell configure to handle variables for | ||||
| @@ -482,8 +530,6 @@ AST_EXT_LIB_SETUP([CODEC2], [Codec 2 Audio Decoder/Encoder], [codec2]) | ||||
| AST_EXT_LIB_SETUP([COROSYNC], [Corosync], [cpg]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([COROSYNC_CFG_STATE_TRACK], [A callback only in corosync 1.x], [COROSYNC], [cfg]) | ||||
| AST_EXT_LIB_SETUP([CRYPT], [password and data encryption], [crypt]) | ||||
| AST_EXT_LIB_SETUP([CRYPTO], [OpenSSL Cryptography], [crypto]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([OPENSSL_BIO_METHOD], [OpenSSL BIO Method Support], [CRYPTO], [crypto]) | ||||
| AST_EXT_LIB_SETUP([DAHDI], [DAHDI], [dahdi]) | ||||
| AST_EXT_LIB_SETUP([FFMPEG], [Ffmpeg and avcodec], [avcodec]) | ||||
| AST_EXT_LIB_SETUP([GSM], [External GSM], [gsm], [, use 'internal' GSM otherwise]) | ||||
| @@ -588,7 +634,6 @@ AST_EXT_LIB_SETUP_OPTIONAL([SRTP_192], [SRTP Library AES-192 (ICM)], [SRTP], [sr | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([SRTP_GCM], [SRTP Library AES-128 (GCM) and AES-256 (GCM)], [SRTP], [srtp]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([SRTP_SHUTDOWN], [SRTP Library Shutdown Function], [SRTP], [srtp]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([SRTP_GET_VERSION], [SRTP Library Version Function], [SRTP], [srtp]) | ||||
| AST_EXT_LIB_SETUP([OPENSSL], [OpenSSL Secure Sockets Layer], [ssl]) | ||||
| AST_EXT_LIB_SETUP_OPTIONAL([RT], [Realtime functions], [rt]) | ||||
| AST_EXT_LIB_SETUP([FREETDS], [FreeTDS], [tds]) | ||||
| AST_EXT_LIB_SETUP([TIMERFD], [timerfd], [timerfd]) | ||||
| @@ -633,8 +678,6 @@ AC_CHECK_HEADERS([ \ | ||||
|  | ||||
| AC_CHECK_HEADERS([arpa/inet.h libintl.h malloc.h netdb.h stddef.h strings.h sys/event.h utime.h]) | ||||
|  | ||||
| PKG_PROG_PKG_CONFIG() | ||||
|  | ||||
| # Find required NetBSD Editline library (libedit). | ||||
| AST_PKG_CONFIG_CHECK(LIBEDIT, libedit) | ||||
| # some platforms do not list libedit via pkg-config, for example OpenBSD 6.2 | ||||
| @@ -2614,14 +2657,6 @@ AC_SUBST(CRYPT_INCLUDE) | ||||
| AC_CHECK_LIB([crypt], [crypt_r], | ||||
|     [AC_DEFINE([HAVE_CRYPT_R], [1], [Define to 1 if you have the 'crypt_r' function.])]) | ||||
|  | ||||
| AST_EXT_LIB_CHECK([CRYPTO], [crypto], [AES_encrypt], [openssl/aes.h]) | ||||
|  | ||||
| if test "$PBX_CRYPTO" = "1"; | ||||
| then | ||||
| 	AST_EXT_LIB_CHECK([OPENSSL], [ssl], [SSL_connect], [openssl/ssl.h], [-lcrypto]) | ||||
| 	AST_EXT_LIB_CHECK([OPENSSL_BIO_METHOD], [ssl], [BIO_meth_new], [openssl/ssl.h], [-lcrypto]) | ||||
| fi | ||||
|  | ||||
| if test "$PBX_OPENSSL" = "1"; | ||||
| then | ||||
|         AST_CHECK_OSPTK([4], [0], [0]) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user