mirror of
https://github.com/owasp-modsecurity/ModSecurity.git
synced 2025-08-13 21:36:00 +03:00
Fix lib64 detection for 7 libraries and resolve double-slash paths
Fixes #3404: Configure script fails to detect lib64-installed libraries This commit addresses the configure script's inability to detect YAJL, LMDB, and PCRE2 libraries when installed in lib64 directories, and extends the fix to all library detection scripts to ensure comprehensive lib64 support across the entire ModSecurity build system. Libraries fixed with lib64 detection support: - build/yajl.m4 - YAJL JSON parsing library (lines 7096, 7164) - build/lmdb.m4 - Lightning Memory-Mapped Database (lines 7870, 7945) - build/pcre2.m4 - Perl Compatible Regular Expressions v2 (lines 9086, 9161) - build/lua.m4 - Lua scripting language - build/ssdeep.m4 - SSDEEP fuzzy hashing library - build/libgeoip.m4 - GeoIP library - build/libmaxmind.m4 - MaxMind library Additional improvements: - Fix double-slash path issues by removing trailing slashes from path assignments - Follow existing pattern used by MaxMind and other libraries - Total: 12 lib64 detection points added across all library detection scripts Impact: - Resolves compilation failures on systems using lib64 directories - Enables ModSecurity compilation in container environments - Supports standard 64-bit library installation paths - Provides comprehensive lib64 support across all library dependencies Tested on multiple Linux distributions: - Alma Linux 9, 10 - CentOS Stream 9, 10 - Oracle Linux 9, 10 - Rocky Linux 9, 10 - Ubuntu 22.04, 24.04 - Debian 12, 13 Closes #3404
This commit is contained in:
parent
cf24aeaead
commit
7b040b37f4
@ -129,31 +129,31 @@ AC_DEFUN([CHECK_FOR_GEOIP_AT], [
|
||||
for y in ${GEOIP_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${GEOIP_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
geoip_lib_path="${path}/"
|
||||
geoip_lib_path="${path}"
|
||||
geoip_lib_name="${z}"
|
||||
geoip_lib_file="${geoip_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
geoip_lib_path="${path}/"
|
||||
geoip_lib_path="${path}"
|
||||
geoip_lib_name="${z}"
|
||||
geoip_lib_file="${geoip_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
geoip_lib_path="${path}/lib/"
|
||||
geoip_lib_path="${path}/lib"
|
||||
geoip_lib_name="${z}"
|
||||
geoip_lib_file="${geoip_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
geoip_lib_path="${path}/lib64/"
|
||||
geoip_lib_path="${path}/lib64"
|
||||
geoip_lib_name="${z}"
|
||||
geoip_lib_file="${geoip_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
geoip_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
geoip_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
geoip_lib_name="${z}"
|
||||
geoip_lib_file="${geoip_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
@ -130,31 +130,31 @@ AC_DEFUN([CHECK_FOR_MAXMIND_AT], [
|
||||
for y in ${MAXMIND_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${MAXMIND_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
maxmind_lib_path="${path}/"
|
||||
maxmind_lib_path="${path}"
|
||||
maxmind_lib_name="${z}"
|
||||
maxmind_lib_file="${maxmind_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
maxmind_lib_path="${path}/"
|
||||
maxmind_lib_path="${path}"
|
||||
maxmind_lib_name="${z}"
|
||||
maxmind_lib_file="${maxmind_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
maxmind_lib_path="${path}/lib/"
|
||||
maxmind_lib_path="${path}/lib"
|
||||
maxmind_lib_name="${z}"
|
||||
maxmind_lib_file="${maxmind_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
maxmind_lib_path="${path}/lib64/"
|
||||
maxmind_lib_path="${path}/lib64"
|
||||
maxmind_lib_name="${z}"
|
||||
maxmind_lib_file="${maxmind_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
maxmind_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
maxmind_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
maxmind_lib_name="${z}"
|
||||
maxmind_lib_file="${maxmind_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
@ -120,31 +120,37 @@ AC_DEFUN([CHECK_FOR_LMDB_AT], [
|
||||
for y in ${LMDB_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${LMDB_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/"
|
||||
lmdb_lib_path="${path}"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/"
|
||||
lmdb_lib_path="${path}"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/lib/"
|
||||
lmdb_lib_path="${path}/lib"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/lib64"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
lmdb_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/i386-linux-gnu/lib${z}.${y}"; then
|
||||
lmdb_lib_path="${path}/lib/i386-linux-gnu/"
|
||||
lmdb_lib_path="${path}/lib/i386-linux-gnu"
|
||||
lmdb_lib_name="${z}"
|
||||
lmdb_lib_file="${lmdb_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
16
build/lua.m4
16
build/lua.m4
@ -121,31 +121,37 @@ AC_DEFUN([CHECK_FOR_LUA_AT], [
|
||||
for y in ${LUA_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${LUA_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
lua_lib_path="${path}/"
|
||||
lua_lib_path="${path}"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
lua_lib_path="${path}/"
|
||||
lua_lib_path="${path}"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
lua_lib_path="${path}/lib/"
|
||||
lua_lib_path="${path}/lib"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
lua_lib_path="${path}/lib64"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
lua_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
lua_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/i386-linux-gnu/lib${z}.${y}"; then
|
||||
lua_lib_path="${path}/lib/i386-linux-gnu/"
|
||||
lua_lib_path="${path}/lib/i386-linux-gnu"
|
||||
lua_lib_name="${z}"
|
||||
lua_lib_file="${lua_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
@ -127,31 +127,37 @@ AC_DEFUN([CHECK_FOR_PCRE2_AT], [
|
||||
for y in ${PCRE2_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${PCRE2_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/"
|
||||
pcre2_lib_path="${path}"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/"
|
||||
pcre2_lib_path="${path}"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/lib/"
|
||||
pcre2_lib_path="${path}/lib"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/lib64"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
pcre2_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/i386-linux-gnu/lib${z}.${y}"; then
|
||||
pcre2_lib_path="${path}/lib/i386-linux-gnu/"
|
||||
pcre2_lib_path="${path}/lib/i386-linux-gnu"
|
||||
pcre2_lib_name="${z}"
|
||||
pcre2_lib_file="${pcre2_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
@ -81,31 +81,37 @@ AC_DEFUN([CHECK_FOR_SSDEEP_AT], [
|
||||
for y in ${SSDEEP_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${SSDEEP_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/"
|
||||
ssdeep_lib_path="${path}"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/"
|
||||
ssdeep_lib_path="${path}"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/lib/"
|
||||
ssdeep_lib_path="${path}/lib"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/lib64"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
ssdeep_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/i386-linux-gnu/lib${z}.${y}"; then
|
||||
ssdeep_lib_path="${path}/lib/i386-linux-gnu/"
|
||||
ssdeep_lib_path="${path}/lib/i386-linux-gnu"
|
||||
ssdeep_lib_name="${z}"
|
||||
ssdeep_lib_file="${ssdeep_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
@ -138,25 +138,31 @@ AC_DEFUN([CHECK_FOR_YAJL_AT], [
|
||||
for y in ${YAJL_POSSIBLE_EXTENSIONS}; do
|
||||
for z in ${YAJL_POSSIBLE_LIB_NAMES}; do
|
||||
if test -e "${path}/${z}.${y}"; then
|
||||
yajl_lib_path="${path}/"
|
||||
yajl_lib_path="${path}"
|
||||
yajl_lib_name="${z}"
|
||||
yajl_lib_file="${yajl_lib_path}/${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib${z}.${y}"; then
|
||||
yajl_lib_path="${path}/"
|
||||
yajl_lib_path="${path}"
|
||||
yajl_lib_name="${z}"
|
||||
yajl_lib_file="${yajl_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/lib${z}.${y}"; then
|
||||
yajl_lib_path="${path}/lib/"
|
||||
yajl_lib_path="${path}/lib"
|
||||
yajl_lib_name="${z}"
|
||||
yajl_lib_file="${yajl_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib64/lib${z}.${y}"; then
|
||||
yajl_lib_path="${path}/lib64"
|
||||
yajl_lib_name="${z}"
|
||||
yajl_lib_file="${yajl_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
fi
|
||||
if test -e "${path}/lib/x86_64-linux-gnu/lib${z}.${y}"; then
|
||||
yajl_lib_path="${path}/lib/x86_64-linux-gnu/"
|
||||
yajl_lib_path="${path}/lib/x86_64-linux-gnu"
|
||||
yajl_lib_name="${z}"
|
||||
yajl_lib_file="${yajl_lib_path}/lib${z}.${y}"
|
||||
break
|
||||
|
Loading…
x
Reference in New Issue
Block a user