haproxy: new package
authorFabrice Fontaine <fontaine.fabrice@gmail.com>
Fri, 21 Sep 2018 20:56:19 +0000 (22:56 +0200)
committerPeter Korsgaard <peter@korsgaard.com>
Thu, 27 Sep 2018 19:40:34 +0000 (21:40 +0200)
HAProxy is a free, very fast and reliable solution offering
high availability, load balancing, and proxying for TCP and
HTTP-based applications.

http://www.haproxy.org

Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Signed-off-by: Peter Korsgaard <peter@korsgaard.com>
DEVELOPERS
package/Config.in
package/haproxy/Config.in [new file with mode: 0644]
package/haproxy/haproxy.hash [new file with mode: 0644]
package/haproxy/haproxy.mk [new file with mode: 0644]

index 0335aef3b1e3fd2388dcc1d1d25dbc4fe6db92eb..c036fa30c4859eb3f15b9f6d8b363bdda3d3eda7 100644 (file)
@@ -743,6 +743,7 @@ F:  package/gssdp/
 F:     package/gupnp/
 F:     package/gupnp-dlna/
 F:     package/gupnp-tools/
+F:     package/haproxy/
 F:     package/hiredis/
 F:     package/i2pd/
 F:     package/igd2-for-linux/
index 52f11c407ad22afd9b17ab3912f79c8189d8da20..8fd60cdec2266c722dc855b73fc55bdeb8ec8668 100644 (file)
@@ -1790,6 +1790,7 @@ menu "Networking applications"
        source "package/gupnp-tools/Config.in"
        source "package/gutenprint/Config.in"
        source "package/hans/Config.in"
+       source "package/haproxy/Config.in"
        source "package/hiawatha/Config.in"
        source "package/hostapd/Config.in"
        source "package/hplip/Config.in"
diff --git a/package/haproxy/Config.in b/package/haproxy/Config.in
new file mode 100644 (file)
index 0000000..cbcbc0c
--- /dev/null
@@ -0,0 +1,10 @@
+config BR2_PACKAGE_HAPROXY
+       bool "haproxy"
+       depends on BR2_USE_MMU # fork()
+       depends on BR2_TOOLCHAIN_HAS_SYNC_4 # __sync_*_4 intrisics
+       help
+         HAProxy is a free, very fast and reliable solution offering
+         high availability, load balancing, and proxying for TCP and
+         HTTP-based applications.
+
+         http://www.haproxy.org
diff --git a/package/haproxy/haproxy.hash b/package/haproxy/haproxy.hash
new file mode 100644 (file)
index 0000000..e6fcb3b
--- /dev/null
@@ -0,0 +1,5 @@
+# Locally computed:
+sha256 2bf5dafbb5f1530c0e67ab63666565de948591f8e0ee2a1d3c84c45e738220f1        haproxy-1.8.13.tar.gz
+sha256 0717ca51fceaa25ac9e5ccc62e0c727dcf27796057201fb5fded56a25ff6ca28        LICENSE
+sha256 5df07007198989c622f5d41de8d703e7bef3d0e79d62e24332ee739a452af62a        doc/lgpl.txt
+sha256 ddb9db7630752f8fdc6898f7c99a99eaeeac5213627ecb093df9c82f56175dc7        doc/gpl.txt
diff --git a/package/haproxy/haproxy.mk b/package/haproxy/haproxy.mk
new file mode 100644 (file)
index 0000000..ea8a3c7
--- /dev/null
@@ -0,0 +1,85 @@
+################################################################################
+#
+# haproxy
+#
+################################################################################
+
+HAPROXY_VERSION_MAJOR = 1.8
+HAPROXY_VERSION = $(HAPROXY_VERSION_MAJOR).13
+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_MAKE_OPTS = \
+       LD=$(TARGET_CC) \
+       PREFIX=/usr \
+       TARGET=custom
+
+ifeq ($(BR2_TOOLCHAIN_HAS_LIBATOMIC),y)
+HAPROXY_LIBS += -latomic
+endif
+
+ifeq ($(BR2_TOOLCHAIN_HAS_THREADS),y)
+HAPROXY_MAKE_OPTS += USE_THREAD=1
+endif
+
+ifeq ($(BR2_PACKAGE_LUA_5_3),y)
+HAPROXY_DEPENDENCIES += lua
+HAPROXY_MAKE_OPTS += 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
+# Set PCRE2_DIR as haproxy will otherwise try to use pcre2-config and
+# will default to /usr/local
+ifeq ($(BR2_PACKAGE_PCRE2),y)
+HAPROXY_DEPENDENCIES += pcre2
+HAPROXY_MAKE_OPTS += \
+       PCRE2DIR=$(STAGING_DIR)/usr \
+       USE_PCRE2=1
+
+# Again, set manually PCRE2_LDFLAGS or default will contain -L/usr/local
+ifeq ($(BR2_PACKAGE_PCRE2_32),y)
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-32
+else ifeq ($(BR2_PACKAGE_PCRE2_16),y)
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-16
+else
+HAPROXY_MAKE_OPTS += PCRE2_LDFLAGS=-lpcre2-8
+endif
+else ifeq ($(BR2_PACKAGE_PCRE),y)
+HAPROXY_DEPENDENCIES += pcre
+HAPROXY_MAKE_OPTS += \
+       PCREDIR=$(STAGING_DIR)/usr \
+       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)"
+
+define HAPROXY_BUILD_CMDS
+       $(TARGET_MAKE_ENV) $(MAKE) $(TARGET_CONFIGURE_OPTS) \
+               $(HAPROXY_MAKE_OPTS) -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))