a380e05833
Fixes the following security issues: - CVE-2021-39240: An issue was discovered in HAProxy 2.2 before 2.2.16, 2.3 before 2.3.13, and 2.4 before 2.4.3. It does not ensure that the scheme and path portions of a URI have the expected characters. For example, the authority field (as observed on a target HTTP/2 server) might differ from what the routing rules were intended to achieve. - CVE-2021-39241: An issue was discovered in HAProxy 2.0 before 2.0.24, 2.2 before 2.2.16, 2.3 before 2.3.13, and 2.4 before 2.4.3. An HTTP method name may contain a space followed by the name of a protected resource. It is possible that a server would interpret this as a request for that protected resource, such as in the "GET /admin? HTTP/1.1 /static/images HTTP/1.1" example. - CVE-2021-39242: An issue was discovered in HAProxy 2.2 before 2.2.16, 2.3 before 2.3.13, and 2.4 before 2.4.3. It can lead to a situation with an attacker-controlled HTTP Host header, because a mismatch between Host and authority is mishandled. For more details, see the advisory: https://www.mail-archive.com/haproxy@formilux.org/msg41041.html Signed-off-by: Peter Korsgaard <peter@korsgaard.com> Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
94 lines
2.3 KiB
Makefile
94 lines
2.3 KiB
Makefile
################################################################################
|
|
#
|
|
# haproxy
|
|
#
|
|
################################################################################
|
|
|
|
HAPROXY_VERSION_MAJOR = 2.4
|
|
HAPROXY_VERSION = $(HAPROXY_VERSION_MAJOR).3
|
|
HAPROXY_SITE = http://www.haproxy.org/download/$(HAPROXY_VERSION_MAJOR)/src
|
|
HAPROXY_LICENSE = GPL-2.0+ and LGPL-2.1+ with exceptions
|
|
HAPROXY_LICENSE_FILES = LICENSE doc/lgpl.txt doc/gpl.txt
|
|
HAPROXY_CPE_ID_VENDOR = haproxy
|
|
|
|
HAPROXY_MAKE_OPTS = \
|
|
LD=$(TARGET_CC) \
|
|
PREFIX=/usr \
|
|
TARGET=custom
|
|
|
|
ifeq ($(BR2_STATIC_LIBS),)
|
|
HAPROXY_MAKE_OPTS += USE_DL=1
|
|
endif
|
|
|
|
ifeq ($(BR2_TOOLCHAIN_HAS_LIBATOMIC),y)
|
|
HAPROXY_LIBS += -latomic
|
|
endif
|
|
|
|
ifeq ($(BR2_TOOLCHAIN_HAS_THREADS_NPTL),y)
|
|
# threads uses atomics on gcc >= 4.7 and sync otherwise (see
|
|
# include/common/hathreads.h)
|
|
ifeq ($(BR2_TOOLCHAIN_GCC_AT_LEAST_4_7):$(BR2_TOOLCHAIN_HAS_ATOMIC),y:y)
|
|
HAPROXY_MAKE_OPTS += USE_THREAD=1
|
|
else ifeq ($(BR2_TOOLCHAIN_GCC_AT_LEAST_4_7):$(BR2_TOOLCHAIN_HAS_SYNC_4),:y)
|
|
HAPROXY_MAKE_OPTS += USE_THREAD=1
|
|
endif
|
|
endif
|
|
|
|
ifeq ($(BR2_PACKAGE_LUA_5_3),y)
|
|
HAPROXY_DEPENDENCIES += lua
|
|
HAPROXY_MAKE_OPTS += \
|
|
LUA_LIB_NAME=lua \
|
|
USE_LUA=1
|
|
endif
|
|
|
|
ifeq ($(BR2_PACKAGE_OPENSSL),y)
|
|
HAPROXY_DEPENDENCIES += openssl
|
|
HAPROXY_MAKE_OPTS += USE_OPENSSL=1
|
|
ifeq ($(BR2_STATIC_LIBS),y)
|
|
HAPROXY_LIBS += -lz
|
|
endif
|
|
endif
|
|
|
|
# pcre and pcre2 can't be enabled at the same time so prefer pcre2
|
|
ifeq ($(BR2_PACKAGE_PCRE2),y)
|
|
HAPROXY_DEPENDENCIES += pcre2
|
|
HAPROXY_MAKE_OPTS += \
|
|
PCRE2_CONFIG=$(STAGING_DIR)/usr/bin/pcre2-config \
|
|
USE_PCRE2=1
|
|
else ifeq ($(BR2_PACKAGE_PCRE),y)
|
|
HAPROXY_DEPENDENCIES += pcre
|
|
HAPROXY_MAKE_OPTS += \
|
|
PCRE_CONFIG=$(STAGING_DIR)/usr/bin/pcre-config \
|
|
USE_PCRE=1
|
|
endif
|
|
|
|
ifeq ($(BR2_PACKAGE_SYSTEMD),y)
|
|
HAPROXY_DEPENDENCIES += systemd
|
|
HAPROXY_MAKE_OPTS += USE_SYSTEMD=1
|
|
endif
|
|
|
|
ifeq ($(BR2_PACKAGE_ZLIB),y)
|
|
HAPROXY_DEPENDENCIES += zlib
|
|
HAPROXY_MAKE_OPTS += USE_ZLIB=1
|
|
endif
|
|
|
|
HAPROXY_MAKE_OPTS += ADDLIB="$(HAPROXY_LIBS)"
|
|
|
|
HAPROXY_CFLAGS = $(TARGET_CFLAGS)
|
|
|
|
ifeq ($(BR2_TOOLCHAIN_HAS_GCC_BUG_90620),y)
|
|
HAPROXY_CFLAGS += -O0
|
|
endif
|
|
|
|
define HAPROXY_BUILD_CMDS
|
|
$(TARGET_MAKE_ENV) $(MAKE) $(TARGET_CONFIGURE_OPTS) \
|
|
$(HAPROXY_MAKE_OPTS) CFLAGS="$(HAPROXY_CFLAGS)" -C $(@D)
|
|
endef
|
|
|
|
define HAPROXY_INSTALL_TARGET_CMDS
|
|
$(TARGET_MAKE_ENV) $(MAKE) $(TARGET_CONFIGURE_OPTS) \
|
|
$(HAPROXY_MAKE_OPTS) -C $(@D) DESTDIR=$(TARGET_DIR) install
|
|
endef
|
|
|
|
$(eval $(generic-package))
|