# Copyright 2011-2020 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=7 PYTHON_COMPAT=( python{3_6,3_7} ) PYTHON_REQ_USE="xml" inherit eutils linux-info python-any-r1 readme.gentoo-r1 if [[ ${PV} == 9999 ]]; then EGIT_REPO_URI="https://gitlab.com/openconnect/openconnect.git" inherit git-r3 autotools else ARCHIVE_URI="ftp://ftp.infradead.org/pub/${PN}/${P}.tar.gz" KEYWORDS="amd64 arm arm64 ppc64 x86" fi VPNC_VER=20190611 SRC_URI="${ARCHIVE_URI} ftp://ftp.infradead.org/pub/vpnc-scripts/vpnc-scripts-${VPNC_VER}.tar.gz" DESCRIPTION="Free client for Cisco AnyConnect SSL VPN software" HOMEPAGE="http://www.infradead.org/openconnect.html" LICENSE="LGPL-2.1 GPL-2" SLOT="0/5" IUSE="doc +gnutls gssapi libproxy lz4 nls smartcard static-libs stoken" DEPEND=" dev-libs/libxml2 sys-libs/zlib !gnutls? ( >=dev-libs/openssl-1.0.1h:0=[static-libs?] ) gnutls? ( app-crypt/trousers app-misc/ca-certificates dev-libs/nettle >=net-libs/gnutls-3:0=[static-libs?] ) gssapi? ( virtual/krb5 ) libproxy? ( net-libs/libproxy ) lz4? ( app-arch/lz4:= ) nls? ( virtual/libintl ) smartcard? ( sys-apps/pcsc-lite:0= ) stoken? ( app-crypt/stoken ) " RDEPEND="${DEPEND} sys-apps/iproute2 " BDEPEND=" virtual/pkgconfig doc? ( ${PYTHON_DEPS} sys-apps/groff ) nls? ( sys-devel/gettext ) " CONFIG_CHECK="~TUN" pkg_pretend() { check_extra_config } pkg_setup() { : } src_unpack() { if [[ ${PV} == 9999 ]]; then git-r3_src_unpack fi default } src_prepare() { default if [[ ${PV} == 9999 ]]; then eautoreconf fi } src_configure() { if use doc; then python_setup else export ac_cv_path_PYTHON= fi # Used by tests if userpriv is disabled addwrite /run/netns local myconf=( --with-vpnc-script="${EPREFIX}/etc/openconnect/openconnect.sh" --without-openssl-version-check $(use_enable static-libs static) $(use_enable nls) $(use_with !gnutls openssl) $(use_with gnutls) $(use_with libproxy) $(use_with lz4) $(use_with gssapi) $(use_with smartcard libpcsclite) $(use_with stoken) --without-java ) econf "${myconf[@]}" } DOC_CONTENTS="The init script for openconnect supports multiple vpn tunnels. You need to create a symbolic link to /etc/init.d/openconnect in /etc/init.d instead of calling it directly: ln -s /etc/init.d/openconnect /etc/init.d/openconnect.vpn0 You can then start the vpn tunnel like this: /etc/init.d/openconnect.vpn0 start If you would like to run preup, postup, predown, and/or postdown scripts, You need to create a directory in /etc/openconnect with the name of the vpn: mkdir /etc/openconnect/vpn0 Then add executable shell files: mkdir /etc/openconnect/vpn0 cd /etc/openconnect/vpn0 echo '#!/bin/sh' > preup.sh cp preup.sh predown.sh cp preup.sh postup.sh cp preup.sh postdown.sh chmod 755 /etc/openconnect/vpn0/* " src_install() { default newinitd "${FILESDIR}"/openconnect.init.in-r4 openconnect insinto /etc/openconnect newconfd "${FILESDIR}"/openconnect.conf.in openconnect exeinto /etc/openconnect newexe "${WORKDIR}"/vpnc-scripts-${VPNC_VER}/vpnc-script openconnect.sh insinto /etc/logrotate.d newins "${FILESDIR}"/openconnect.logrotate openconnect keepdir /var/log/openconnect find "${ED}" -name '*.la' -delete || die readme.gentoo_create_doc } pkg_postinst() { readme.gentoo_print_elog if [[ -z ${REPLACING_VERSIONS} ]]; then elog elog "You may want to consider installing the following optional packages." optfeature "resolvconf support" virtual/resolvconf fi }