COMPONENT_TARGETS = $(HARDWARE_INTEL_PC32)
COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
COMPONENT_TARGETS += $(HARDWARE_CB1X)
COMPONENT_TARGETS += $(HARDWARE_CB2X)
COMPONENT_TARGETS += $(HARDWARE_CB3X)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5B)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5P)
COMPONENT_TARGETS += $(HARDWARE_ROCK_5B)
COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
COMPONENT_TARGETS += $(HARDWARE_REPKA_PI3)
COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
COMPONENT_TARGETS += $(HARDWARE_POIN2)
COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
COMPONENT_TARGETS += $(HARDWARE_M201)
COMPONENT_TARGETS += $(HARDWARE_MXV)
COMPONENT_TARGETS += $(HARDWARE_P201)
COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
COMPONENT_TARGETS += $(HARDWARE_P212)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
COMPONENT_TARGETS += $(HARDWARE_Q201)
COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
COMPONENT_TARGETS += $(HARDWARE_CI20)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
COMPONENT_TARGETS += $(HARDWARE_S824L)
COMPONENT_TARGETS += $(HARDWARE_VESNIN)
COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
COMPONENT_TARGETS += $(HARDWARE_VISIONFIVE2)
COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
NEED_ABS_PATH = true
COMPONENT_IS_3PP = true
include ../../../build-system/constants.mk
SOURCE_REQUIRES = sources/packages/n/openvpn
REQUIRES = libs/lz4/1.9.4
REQUIRES += libs/lzo/2.10
REQUIRES += net/libnsl/1.3.0
REQUIRES += net/openssl/1.1.1r
REQUIRES += secure/pam/1.5.1
# ======= __END_OF_REQUIRES__ =======
version = 2.5.2
tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/n/openvpn/openvpn-$(version).tar.xz
SRC_ARCHIVE = $(tar_xz_archive)
SRC_DIR = $(TARGET_BUILD_DIR)/openvpn-$(version)
src_dir_name = openvpn-$(version)
src_done = $(TARGET_BUILD_DIR)/.source_done
PATCHES = PATCHES
build_dir = $(TARGET_BUILD_DIR)/build
build_target = $(TARGET_BUILD_DIR)/.build_done
install_target = $(TARGET_BUILD_DIR)/.install_done
openvpn_init_d = $(CURDIR)/conf/rc.openvpn
openvpn_sample = $(CURDIR)/conf/radix.conf
openvpn_readme = $(CURDIR)/conf/README.TXT
####### Targets
PKG_GROUP = net
#
# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
#
OPENVPN_PKG_NAME = openvpn
OPENVPN_PKG_VERSION = 2.5.2
OPENVPN_PKG_ARCH = $(PKGARCH)
OPENVPN_PKG_DISTRO_NAME = $(DISTRO_NAME)
OPENVPN_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
OPENVPN_PKG_GROUP = $(PKG_GROUP)
### |---handy-ruler-------------------------------|
OPENVPN_PKG_SHORT_DESCRIPTION = secure IP tunnel daemon
OPENVPN_PKG_URL = $(BUG_URL)
OPENVPN_PKG_LICENSE = GPLv2
OPENVPN_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(OPENVPN_PKG_NAME)-pkg-description
OPENVPN_PKG_DESCRIPTION_FILE_IN = $(OPENVPN_PKG_NAME)-pkg-description.in
OPENVPN_PKG_INSTALL_SCRIPT = $(OPENVPN_PKG_NAME)-pkg-install.sh
OPENVPN_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(OPENVPN_PKG_NAME)-package
pkg_basename = $(OPENVPN_PKG_NAME)-$(OPENVPN_PKG_VERSION)-$(OPENVPN_PKG_ARCH)-$(OPENVPN_PKG_DISTRO_NAME)-$(OPENVPN_PKG_DISTRO_VERSION)
pkg_archive = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
pkg_certificate = $(call cert-name,$(pkg_archive))
pkg_signature = $(call sign-name,$(pkg_archive))
pkg_description = $(call desc-name,$(pkg_archive))
products = $(call pkg-files,$(pkg_archive))
BUILD_TARGETS = $(build_target)
BUILD_TARGETS += $(install_target)
PRODUCT_TARGETS = $(products)
ROOTFS_TARGETS = $(pkg_archive)
include ../../../build-system/core.mk
env_sysroot = DESTDIR=$(OPENVPN_PKG)
extra_configure_switches = --libdir=/usr/lib$(LIBSUFFIX)
extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
extra_configure_switches += --mandir=/usr/share/man
extra_configure_switches += --sysconfdir=/etc/openvpn
extra_configure_switches += --localstatedir=/var
extra_configure_switches += --with-crypto-library=openssl
extra_configure_switches += --enable-lz4
extra_configure_switches += --enable-lzo
extra_configure_switches += --enable-iproute2
extra_configure_switches += --enable-plugins
extra_configure_switches += --enable-plugin-auth-pam
extra_configure_switches += --enable-plugin-down-root
extra_configure_switches += --disable-unit-tests
ifeq ($(__ENABLE_STATIC__),yes)
extra_configure_switches += --enable-static=yes
else
extra_configure_switches += --enable-static=no
endif
extra_configure_switches += --enable-shared=yes
CFLAGS += -Wformat-overflow=0
LDFLAGS += -Wl,-rpath,/lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
TARGET_BIN_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
TARGET_LIB_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX):/usr/lib/../lib$(LIBSUFFIX)
####### Dependencies
$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
$(UNPACK_SRC_ARCHIVE)
$(APPLY_PATCHES)
@( cd $(SRC_DIR) ; autoreconf -vif )
@touch $@
$(build_target): $(src_done)
@mkdir -p $(build_dir)
@cd $(build_dir) && $(BUILD_ENVIRONMENT) ../$(src_dir_name)/configure \
--prefix=/usr \
--build=$(BUILD) \
--host=$(TARGET) \
$(extra_configure_switches)
@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE)
@touch $@
$(install_target): $(build_target)
@mkdir -p $(OPENVPN_PKG)/etc/rc.d
@cd $(build_dir) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
# ======= Install a startup script =======
@cat $(openvpn_init_d) > $(OPENVPN_PKG)/etc/rc.d/rc.openvpn.new
@chmod 644 $(OPENVPN_PKG)/etc/rc.d/rc.openvpn.new
# ======= Create a decent config directories =======
@mkdir -p $(OPENVPN_PKG)/etc/openvpn/{certs,keys}
@chmod 750 $(OPENVPN_PKG)/etc/openvpn/{certs,keys}
@cat $(openvpn_readme) > $(OPENVPN_PKG)/etc/openvpn/README.TXT
# ======= Install Documentation =======
@if [ -d $(OPENVPN_PKG)/usr/share/man ]; then \
( cd $(OPENVPN_PKG)/usr/share/man ; \
for manpagedir in `find . -type d -name "man*"` ; do \
( cd $$manpagedir ; \
for eachpage in `find . -type l -maxdepth 1` ; do \
ln -s `readlink $$eachpage`.gz $$eachpage.gz ; \
rm $$eachpage ; \
done ; \
gzip -9 *.? ; \
) \
done \
) \
fi
@mkdir -p $(OPENVPN_PKG)/usr/doc/$(src_dir_name)
@cp -a $(SRC_DIR)/AUTHORS $(SRC_DIR)/COPYING $(SRC_DIR)/COPYRIGHT.GPL \
$(OPENVPN_PKG)/usr/doc/$(src_dir_name)
@mkdir -p $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)
@( cd $(SRC_DIR) ; \
cp -a AUTHORS COPYING COPYRIGHT.GPL Changes.rst INSTALL PORTS README* TODO* \
sample/sample-config-files sample/sample-keys sample/sample-scripts \
$(OPENVPN_PKG)/usr/share/doc/$(src_dir_name) ; \
)
@( cd $(SRC_DIR) ; \
if [ -r ChangeLog ]; then \
DOCSDIR=`echo $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)` ; \
cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
fi \
)
# ======= Add a link to sample-config-files =======
@( cd $(OPENVPN_PKG)/etc/openvpn ; \
ln -sf ../../usr/share/doc/$(src_dir_name)/sample-config-files . ; \
)
# ======= Install a reasonably generic sample config file =======
@mkdir -p $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)/sample-config-files
@cp -a $(openvpn_sample) $(OPENVPN_PKG)/usr/share/doc/$(src_dir_name)/sample-config-files
# ======= remove toolchain path from target libtool *.la files =======
@( cd $(OPENVPN_PKG)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
sed -i "s,$(TARGET_DEST_DIR),,g" openvpn-plugin-auth-pam.la openvpn-plugin-down-root.la ; \
)
# ======= Install the same to $(TARGET_DEST_DIR) =======
$(call install-into-devenv, $(OPENVPN_PKG))
# ======= tune libtool *.la search path to the target destination for development =======
@( cd $(TARGET_DEST_DIR)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
sed -i "s,/usr,$(TARGET_DEST_DIR)/usr,g" openvpn-plugin-auth-pam.la \
openvpn-plugin-down-root.la ; \
sed -i "s,L/lib,L$(TARGET_DEST_DIR)/lib,g" openvpn-plugin-auth-pam.la \
openvpn-plugin-down-root.la ; \
sed -i "s,/lib/libpam,$(TARGET_DEST_DIR)/lib/libpam,g" openvpn-plugin-auth-pam.la \
openvpn-plugin-down-root.la ; \
)
# ======= Strip binaries =======
@( cd $(OPENVPN_PKG) ; \
find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null ; \
)
ifneq ($(PATCHELF),)
# ======= Set RPATH/RUNPATH for target binaries =======
@( cd $(OPENVPN_PKG)/usr/sbin ; \
for file in `find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
$(PATCHELF) --set-rpath $(TARGET_BIN_RPATH) $$file 1> /dev/null 2> /dev/null ; \
fi ; \
done ; \
)
# ======= Set RPATH/RUNPATH for target shared objects =======
@( cd $(OPENVPN_PKG)/usr/lib$(LIBSUFFIX)/openvpn/plugins ; \
for file in `find . | xargs file | grep "shared object" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
$(PATCHELF) --set-rpath $(TARGET_LIB_RPATH) $$file 1> /dev/null 2> /dev/null ; \
fi ; \
done ; \
)
endif
@touch $@
$(OPENVPN_PKG_DESCRIPTION_FILE): $(OPENVPN_PKG_DESCRIPTION_FILE_IN)
@cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
$(pkg_certificate) : $(pkg_archive) ;
$(pkg_signature) : $(pkg_archive) ;
$(pkg_description) : $(pkg_archive) ;
$(pkg_archive): $(install_target) $(OPENVPN_PKG_DESCRIPTION_FILE) $(OPENVPN_PKG_INSTALL_SCRIPT)
@cp $(OPENVPN_PKG_DESCRIPTION_FILE) $(OPENVPN_PKG)/.DESCRIPTION
@cp $(OPENVPN_PKG_INSTALL_SCRIPT) $(OPENVPN_PKG)/.INSTALL
@$(BUILD_PKG_REQUIRES) $(OPENVPN_PKG)/.REQUIRES
@echo "pkgname=$(OPENVPN_PKG_NAME)" > $(OPENVPN_PKG)/.PKGINFO ; \
echo "pkgver=$(OPENVPN_PKG_VERSION)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "arch=$(OPENVPN_PKG_ARCH)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "distroname=$(OPENVPN_PKG_DISTRO_NAME)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "distrover=$(OPENVPN_PKG_DISTRO_VERSION)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "group=$(OPENVPN_PKG_GROUP)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "short_description=\"$(OPENVPN_PKG_SHORT_DESCRIPTION)\"" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "url=$(OPENVPN_PKG_URL)" >> $(OPENVPN_PKG)/.PKGINFO ; \
echo "license=$(OPENVPN_PKG_LICENSE)" >> $(OPENVPN_PKG)/.PKGINFO
@$(PSEUDO) sh -c "cd $(OPENVPN_PKG) && \
chown -R root:root . && \
chown -R 0:99 etc/openvpn/{certs,keys} && \
$(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."