From 456ce7b341ac5d06301d1874d39a3ea56d7d8b4b Mon Sep 17 00:00:00 2001 From: Miro Stauder Date: Sun, 8 Dec 2024 10:25:50 +0000 Subject: [PATCH 1/2] make OpenSSL special case only for almalinux8 --- deps/Makefile | 18 +++++++++--------- lib/Makefile | 14 ++++++++++---- src/Makefile | 21 +++++++++++---------- 3 files changed, 30 insertions(+), 23 deletions(-) diff --git a/deps/Makefile b/deps/Makefile index 2823e66db..f7be0f2b9 100644 --- a/deps/Makefile +++ b/deps/Makefile @@ -72,29 +72,29 @@ libinjection: libinjection/libinjection/src/libinjection.a DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') OPENSSL_VERSION_3 := 3.0.0 +ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) +LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) +LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) ifeq ($(DISTRO), almalinux) +ifeq ($(CENTOSVER), 8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so.3" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so.3" 2>/dev/null | head -n 1) - SSL_LDIR := $(dir $(LIB_SSL_PATH)) -else - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) - LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) - LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) - SSL_LDIR := $(dir $(LIB_SSL_PATH)) endif +endif +SSL_LDIR := $(dir $(LIB_SSL_PATH)) ifneq ($(ssl_header_path),) SSL_IDIR := $(shell dirname $(shell dirname $(ssl_header_path))) $(info Found OpenSSL headers at $(SSL_IDIR)) $(info OpenSSL lib full path is $(LIB_SSL_PATH)) - $(info OpenSSL libs directory is $(SSL_LDIR)) + $(info OpenSSL libs directory is $(SSL_LDIR)) else - $(error Warning: OpenSSL headers not found. exiting, please install openssl.) + $(error Warning: OpenSSL headers not found. exiting, please install openssl version 3.) endif check_openssl_version: - @if [ "$(DISTRO)" = "almalinux" ]; then \ + @if [ "$(DISTRO)" = "almalinux" && "$(CENTOSVER)" = "8" ]; then \ @current_version=$$(openssl3 version | awk '{print $$2}'); \ else \ @current_version=$$(openssl version | awk '{print $$2}'); \ diff --git a/lib/Makefile b/lib/Makefile index 0c2d605c3..492d3c4cd 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -6,6 +6,11 @@ ifndef GIT_VERSION $(error GIT_VERSION is not set) endif +CENTOSVER := Unknown +ifneq (,$(wildcard /etc/system-release)) + CENTOSVER := $(shell rpm --eval %rhel) +endif + DEPS_PATH := ../deps UNAME_S := $(shell uname -s) @@ -49,17 +54,18 @@ CURL_IDIR := $(CURL_DIR)/include DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') +ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) ifeq ($(DISTRO), almalinux) +ifeq ($(CENTOSVER), 8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) -else - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) +endif endif ifneq ($(ssl_header_path),) SSL_IDIR := $(shell dirname $(shell dirname $(ssl_header_path))) - $(info Found yash OpenSSL headers at $(SSL_IDIR)) + $(info Found OpenSSL headers at $(SSL_IDIR)) else - $(error Warning: OpenSSL headers not found. exiting, please install openssl.) + $(error Warning: OpenSSL headers not found. exiting, please install openssl version 3.) endif EV_DIR := $(DEPS_PATH)/libev/libev/ diff --git a/src/Makefile b/src/Makefile index 4da9e31e6..a8636e954 100644 --- a/src/Makefile +++ b/src/Makefile @@ -83,25 +83,25 @@ CURL_LDIR := $(CURL_PATH)/lib/.libs DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') +ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) +LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) +LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) ifeq ($(DISTRO), almalinux) +ifeq ($(CENTOSVER), 8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so.3" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so.3" 2>/dev/null | head -n 1) - SSL_LDIR := $(dir $(LIB_SSL_PATH)) -else - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) - LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) - LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) - SSL_LDIR := $(dir $(LIB_SSL_PATH)) endif +endif +SSL_LDIR := $(dir $(LIB_SSL_PATH)) ifneq ($(ssl_header_path),) SSL_IDIR := $(shell dirname $(shell dirname $(ssl_header_path))) $(info Found OpenSSL headers at $(SSL_IDIR)) $(info OpenSSL lib full path is $(LIB_SSL_PATH)) - $(info OpenSSL libs directory is $(SSL_LDIR)) + $(info OpenSSL libs directory is $(SSL_LDIR)) else - $(error Warning: OpenSSL headers not found. exiting, please install openssl.) + $(error Warning: OpenSSL headers not found. exiting, please install openssl version 3.) endif EV_PATH := $(DEPS_PATH)/libev/libev/ @@ -201,10 +201,11 @@ ifeq ($(UNAME_S),Linux) STATICMYLIBS += -lcoredumper endif +MYLIBS := -Wl,--export-dynamic $(STATICMYLIBS) -Wl,-Bdynamic -lgnutls -lpthread -lssl -lcrypto -lm -lz -lrt -lprometheus-cpp-pull -lprometheus-cpp-core -luuid $(EXTRALINK) ifeq ($(DISTRO), almalinux) +ifeq ($(CENTOSVER), 8) MYLIBS := -Wl,--export-dynamic $(STATICMYLIBS) -Wl,-Bdynamic -lgnutls -lpthread $(LIB_SSL_PATH) $(LIB_CRYPTO_PATH) -lm -lz -lrt -lprometheus-cpp-pull -lprometheus-cpp-core -luuid $(EXTRALINK) -else - MYLIBS := -Wl,--export-dynamic $(STATICMYLIBS) -Wl,-Bdynamic -lgnutls -lpthread -lssl -lcrypto -lm -lz -lrt -lprometheus-cpp-pull -lprometheus-cpp-core -luuid $(EXTRALINK) +endif endif ifeq ($(UNAME_S),Darwin) From 9e8deb55786dcf4637a4d0bce1594cff4479ef4b Mon Sep 17 00:00:00 2001 From: Miro Stauder Date: Sun, 8 Dec 2024 16:47:28 +0000 Subject: [PATCH 2/2] fix test and cleanup --- deps/Makefile | 32 +++++++++++++++++++------------- lib/Makefile | 27 +++++++++++++++++++++------ src/Makefile | 19 ++++++++++++------- 3 files changed, 52 insertions(+), 26 deletions(-) diff --git a/deps/Makefile b/deps/Makefile index f7be0f2b9..3ea11a24c 100644 --- a/deps/Makefile +++ b/deps/Makefile @@ -1,15 +1,22 @@ #!/bin/make -f -SYS_KERN := $(shell uname -s) -SYS_ARCH := $(shell uname -m) +GIT_VERSION ?= $(shell git describe --long --abbrev=7) +ifndef GIT_VERSION + $(error GIT_VERSION is not set) +endif + +UNAME_S := $(shell uname -s) +UNAME_M := $(shell uname -m) + +DISTRO := $(shell grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') CENTOSVER := Unknown ifneq (,$(wildcard /etc/system-release)) CENTOSVER := $(shell rpm --eval %rhel) endif -IS_ARM := $(if $(findstring aarch64, $(SYS_ARCH)),true,false) +IS_ARM := $(if $(findstring aarch64, $(UNAME_M)),true,false) IS_CENTOS := $(if $(findstring Unknown, $(CENTOSVER)),false,true) # to compile libmariadb_client with support for valgrind enabled, run: @@ -39,7 +46,7 @@ STDCPP := -std=c++$(shell echo $(CPLUSPLUS) | cut -c3-4) -DCXX$(shell echo $(CPL targets := check_openssl_version libconfig libdaemon jemalloc mariadb_client re2 sqlite3 pcre lz4 cityhash microhttpd curl ev libhttpserver libinjection prometheus-cpp postgresql libusual libscram -ifeq ($(SYS_KERN),Linux) +ifeq ($(UNAME_S),Linux) targets += coredumper endif ifeq ($(PROXYSQLCLICKHOUSE),1) @@ -60,7 +67,7 @@ ifneq ($(CENTOSVER),6) cd libinjection/libinjection && patch -p1 < ../update-build-py3.diff cd libinjection/libinjection && patch -p1 < ../libinjection_sqli.c.patch endif -ifeq ($(SYS_KERN),Darwin) +ifeq ($(UNAME_S),Darwin) sed -i '' 's/CC=/CC?=/' libinjection/libinjection/src/Makefile else sed -i -e 's/CC=/CC?=/' libinjection/libinjection/src/Makefile @@ -69,18 +76,16 @@ endif libinjection: libinjection/libinjection/src/libinjection.a -DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') -OPENSSL_VERSION_3 := 3.0.0 - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) -ifeq ($(DISTRO), almalinux) -ifeq ($(CENTOSVER), 8) +ifeq ($(DISTRO),almalinux) +ifeq ($(CENTOSVER),8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so.3" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so.3" 2>/dev/null | head -n 1) endif +else endif SSL_LDIR := $(dir $(LIB_SSL_PATH)) @@ -93,8 +98,9 @@ else $(error Warning: OpenSSL headers not found. exiting, please install openssl version 3.) endif +OPENSSL_VERSION_3 := 3.0.0 check_openssl_version: - @if [ "$(DISTRO)" = "almalinux" && "$(CENTOSVER)" = "8" ]; then \ + @if [[ "$(DISTRO)" = "almalinux" && "$(CENTOSVER)" = "8" ]]; then \ @current_version=$$(openssl3 version | awk '{print $$2}'); \ else \ @current_version=$$(openssl version | awk '{print $$2}'); \ @@ -148,7 +154,7 @@ curl/curl/lib/.libs/libcurl.a: cd curl && tar -zxf curl-*.tar.gz # cd curl/curl && ./configure --disable-debug --disable-ftp --disable-ldap --disable-ldaps --disable-rtsp --disable-proxy --disable-dict --disable-telnet --disable-tftp --disable-pop3 --disable-imap --disable-smb --disable-smtp --disable-gopher --disable-manual --disable-ipv6 --disable-sspi --disable-crypto-auth --disable-ntlm-wb --disable-tls-srp --without-nghttp2 --without-libidn2 --without-libssh2 --without-brotli --with-ssl=$(shell pwd)/../../libssl/openssl/ && CC=${CC} CXX=${CXX} ${MAKE} cd curl/curl && autoreconf -fi -ifeq ($(SYS_KERN),Darwin) +ifeq ($(UNAME_S),Darwin) cd curl/curl && patch configure < ../configure.patch endif cd curl/curl && CPPFLAGS="-I$(SSL_IDIR)" LDFLAGS="$(LIB_SSL_PATH) $(LIB_CRYPTO_PATH)" ./configure --disable-debug --disable-ftp --disable-ldap --disable-ldaps --disable-rtsp --disable-proxy --disable-dict --disable-telnet --disable-tftp --disable-pop3 --disable-imap --disable-smb --disable-smtp --disable-gopher --disable-manual --disable-ipv6 --disable-sspi --disable-ntlm-wb --disable-tls-srp --without-nghttp2 --without-libidn2 --without-libssh2 --without-brotli --without-librtmp --without-libpsl --without-zstd --with-ssl --enable-shared=yes @@ -307,7 +313,7 @@ re2/re2/obj/libre2.a: # cd re2/re2 && sed -i -e 's/-O3 -g /-O3 -fPIC /' Makefile # cd re2/re2 && patch util/mutex.h < ../mutex.h.patch cd re2/re2 && patch re2/onepass.cc < ../onepass.cc-multiplication-overflow.patch -ifeq ($(SYS_KERN),Darwin) +ifeq ($(UNAME_S),Darwin) cd re2/re2 && sed -i '' -e 's/-O3 -g/-O3 -g -${STDCPP} -fPIC -DMEMORY_SANITIZER -DRE2_ON_VALGRIND /' Makefile # cd re2/re2 && sed -i '' -e 's/RE2_CXXFLAGS?=-std=c++11 /RE2_CXXFLAGS?=-std=c++11 -fPIC /' Makefile else diff --git a/lib/Makefile b/lib/Makefile index 492d3c4cd..9d7754640 100644 --- a/lib/Makefile +++ b/lib/Makefile @@ -6,15 +6,25 @@ ifndef GIT_VERSION $(error GIT_VERSION is not set) endif +UNAME_S := $(shell uname -s) +UNAME_M := $(shell uname -m) + +DISTRO := $(shell grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') + CENTOSVER := Unknown ifneq (,$(wildcard /etc/system-release)) CENTOSVER := $(shell rpm --eval %rhel) endif -DEPS_PATH := ../deps +IS_ARM := $(if $(findstring aarch64, $(UNAME_M)),true,false) +IS_CENTOS := $(if $(findstring Unknown, $(CENTOSVER)),false,true) -UNAME_S := $(shell uname -s) +PROXYSQL_PATH := .. +PROXYSQL_IDIR := $(PROXYSQL_PATH)/include +PROXYSQL_LDIR := $(PROXYSQL_PATH)/lib + +DEPS_PATH := $(PROXYSQL_PATH)/deps MARIADB_PATH := $(DEPS_PATH)/mariadb-client-library/mariadb_client MARIADB_IDIR := $(MARIADB_PATH)/include @@ -52,18 +62,23 @@ COREDUMPER_IDIR := $(COREDUMPER_DIR)/include CURL_DIR := $(DEPS_PATH)/curl/curl CURL_IDIR := $(CURL_DIR)/include -DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) -ifeq ($(DISTRO), almalinux) -ifeq ($(CENTOSVER), 8) +LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) +LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) +ifeq ($(DISTRO),almalinux) +ifeq ($(CENTOSVER),8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) + LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so.3" 2>/dev/null | head -n 1) + LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so.3" 2>/dev/null | head -n 1)endif endif endif +SSL_LDIR := $(dir $(LIB_SSL_PATH)) ifneq ($(ssl_header_path),) SSL_IDIR := $(shell dirname $(shell dirname $(ssl_header_path))) $(info Found OpenSSL headers at $(SSL_IDIR)) + $(info OpenSSL lib full path is $(LIB_SSL_PATH)) + $(info OpenSSL libs directory is $(SSL_LDIR)) else $(error Warning: OpenSSL headers not found. exiting, please install openssl version 3.) endif diff --git a/src/Makefile b/src/Makefile index a8636e954..116d9268f 100644 --- a/src/Makefile +++ b/src/Makefile @@ -6,11 +6,19 @@ ifndef GIT_VERSION $(error GIT_VERSION is not set) endif +UNAME_S := $(shell uname -s) +UNAME_M := $(shell uname -m) + +DISTRO := $(shell grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') + CENTOSVER := Unknown ifneq (,$(wildcard /etc/system-release)) CENTOSVER := $(shell rpm --eval %rhel) endif +IS_ARM := $(if $(findstring aarch64, $(UNAME_M)),true,false) +IS_CENTOS := $(if $(findstring Unknown, $(CENTOSVER)),false,true) + PROXYSQL_PATH := .. PROXYSQL_IDIR := $(PROXYSQL_PATH)/include @@ -81,13 +89,11 @@ CURL_PATH := $(DEPS_PATH)/curl/curl CURL_IDIR := $(CURL_PATH)/include CURL_LDIR := $(CURL_PATH)/lib/.libs -DISTRO := $(shell lsb_release -si 2>/dev/null || grep '^ID=' /etc/os-release | cut -d= -f2 | tr -d '"') - ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so" 2>/dev/null | head -n 1) -ifeq ($(DISTRO), almalinux) -ifeq ($(CENTOSVER), 8) +ifeq ($(DISTRO),almalinux) +ifeq ($(CENTOSVER),8) ssl_header_path := $(shell find /usr /usr/local /opt -name "ssl.h" -path "*/openssl3/*" 2>/dev/null | head -n 1) LIB_SSL_PATH := $(shell find /usr /usr/local /opt -name "libssl.so.3" 2>/dev/null | head -n 1) LIB_CRYPTO_PATH := $(shell find /usr /usr/local /opt -name "libcrypto.so.3" 2>/dev/null | head -n 1) @@ -124,7 +130,6 @@ IDIRS := -I$(PROXYSQL_IDIR) -I$(JEMALLOC_IDIR) -I$(MARIADB_IDIR) -I$(LIBCONFIG_I LDIRS := -L$(PROXYSQL_LDIR) -L$(JEMALLOC_LDIR) -L$(MARIADB_LDIR) -L$(LIBCONFIG_LDIR) -L$(LIBDAEMON_LDIR) -L$(RE2_LDIR) -L$(PCRE_LDIR) -L$(MICROHTTPD_LDIR) -L$(LIBHTTPSERVER_LDIR) -L$(LIBINJECTION_LDIR) -L$(CURL_LDIR) -L$(EV_LDIR) -L$(SSL_LDIR) -L$(PROMETHEUS_LDIR) -L$(POSTGRESQL_LDIR) -L$(LIBUSUAL_LDIR) -L$(LIBSCRAM_LDIR) -UNAME_S := $(shell uname -s) ifeq ($(UNAME_S),Linux) LDIRS += -L$(COREDUMPER_LDIR) endif @@ -202,8 +207,8 @@ ifeq ($(UNAME_S),Linux) endif MYLIBS := -Wl,--export-dynamic $(STATICMYLIBS) -Wl,-Bdynamic -lgnutls -lpthread -lssl -lcrypto -lm -lz -lrt -lprometheus-cpp-pull -lprometheus-cpp-core -luuid $(EXTRALINK) -ifeq ($(DISTRO), almalinux) -ifeq ($(CENTOSVER), 8) +ifeq ($(DISTRO),almalinux) +ifeq ($(CENTOSVER),8) MYLIBS := -Wl,--export-dynamic $(STATICMYLIBS) -Wl,-Bdynamic -lgnutls -lpthread $(LIB_SSL_PATH) $(LIB_CRYPTO_PATH) -lm -lz -lrt -lprometheus-cpp-pull -lprometheus-cpp-core -luuid $(EXTRALINK) endif endif