blob: 991437a2507ab46fe00d86725a0af7a7ba2f6570 [file] [log] [blame]
# Copyright 1999-2018 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
EAPI=6
inherit linux-info multilib pam toolchain-funcs udev user
PATCH_VER="6"
DESCRIPTION="Point-to-Point Protocol (PPP)"
HOMEPAGE="https://ppp.samba.org/"
SRC_URI="https://download.samba.org/pub/ppp/${P}.tar.gz
https://dev.gentoo.org/~polynomial-c/${P}-patches-${PATCH_VER}.tar.xz
http://www.netservers.net.uk/gpl/ppp-dhcpc.tgz"
LICENSE="BSD GPL-2"
SLOT="0/${PV}"
KEYWORDS="*"
IUSE="activefilter atm dhcp eap-tls gtk ipv6 libressl pam radius"
DEPEND="activefilter? ( net-libs/libpcap )
atm? ( net-dialup/linux-atm )
pam? ( virtual/pam )
gtk? ( x11-libs/gtk+:2 )
eap-tls? (
!libressl? ( dev-libs/openssl:0= )
libressl? ( dev-libs/libressl:= )
)"
RDEPEND="${DEPEND}"
PDEPEND="net-dialup/ppp-scripts"
src_prepare() {
mv "${WORKDIR}/dhcp" "${S}/pppd/plugins" || die
if ! use eap-tls ; then
rm "${WORKDIR}"/patch/8?_all_eaptls-* || die
fi
eapply "${WORKDIR}"/patch
# Apply Chromium OS specific patch regarding the nosystemconfig option
# See https://chromium-review.googlesource.com/#/c/7751/ and
# http://crosbug.com/17185 for details.
eapply "${FILESDIR}/${PN}-2.4.6-systemconfig.patch"
# Fix for clang FORTIFY (crbug.com/640358).
eapply "${FILESDIR}/${PN}-remove-ttyname.patch"
eapply "${FILESDIR}/${PN}-2.4.6-allow-non-root.patch"
eapply "${FILESDIR}/${PN}-2.4.6-specify-runtime-data-dir.patch"
eapply "${FILESDIR}/${PN}-2.4.7-no-regain-root.patch"
if use atm ; then
einfo "Enabling PPPoATM support"
sed -i '/^#HAVE_LIBATM=yes/s:#::' \
pppd/plugins/pppoatm/Makefile.linux || die
fi
if ! use activefilter ; then
einfo "Disabling active filter"
sed -i '/^FILTER=y/s:^:#:' pppd/Makefile.linux || die
fi
if use pam ; then
einfo "Enabling PAM"
sed -i '/^#USE_PAM=y/s:^#::' pppd/Makefile.linux || die
fi
if use ipv6 ; then
einfo "Enabling IPv6"
sed -i '/#HAVE_INET6/s:#::' pppd/Makefile.linux || die
echo "+ipv6" >> etc.ppp/options || die
fi
einfo "Enabling CBCP"
sed -i '/^#CBCP=y/s:#::' pppd/Makefile.linux || die
if use dhcp ; then
einfo "Adding ppp-dhcp plugin files"
sed \
-e '/^SUBDIRS :=/s:$: dhcp:' \
-i pppd/plugins/Makefile.linux || die
fi
# Set correct libdir
sed -i -e "s:/lib/pppd:/$(get_libdir)/pppd:" \
pppd/{pathnames.h,pppd.8} || die
if use radius ; then
#set the right paths in radiusclient.conf
sed -e "s:/usr/local/etc:/etc:" \
-e "s:/usr/local/sbin:/usr/sbin:" \
-i pppd/plugins/radius/etc/radiusclient.conf || die
#set config dir to /etc/ppp/radius
sed -i -e "s:/etc/radiusclient:/etc/ppp/radius:g" \
pppd/plugins/radius/{*.8,*.c,*.h} \
pppd/plugins/radius/etc/* || die
else
einfo "Disabling radius"
sed -i -e '/+= radius/s:^:#:' pppd/plugins/Makefile.linux || die
fi
# Respect our pkg-config settings.
sed -i \
-e 's:pkg-config:$(PKG_CONFIG):' \
contrib/pppgetpass/Makefile.linux || die
sed -i \
-e '/^LIBS/{s:-L/usr/local/ssl/lib::;s:-lcrypto:`$(PKG_CONFIG) --libs libcrypto`:}' \
pppd/Makefile.linux || die
eapply_user #549588
}
src_compile() {
tc-export AR CC PKG_CONFIG
append-cppflags \
-D_GNU_SOURCE \
-DRUNTIME_DATA_DIR=\'\"/run/l2tpipsec_vpn/\"\' \
-DALLOW_START_AS_NON_ROOT
emake COPTS="${CFLAGS}"
# build pppgetpass
cd contrib/pppgetpass || die
if use gtk ; then
emake -f Makefile.linux
else
emake pppgetpass.vt
fi
}
src_install() {
local i
for i in chat pppd pppdump pppstats ; do
doman ${i}/${i}.8
dosbin ${i}/${i}
done
fperms -w /usr/sbin/pppd
# Install pppd header files
emake -C pppd INSTROOT="${D}" install-devel
dosbin pppd/plugins/rp-pppoe/pppoe-discovery
dodir /etc/ppp/peers
insinto /etc/ppp
insopts -o shill -g shill -m0600
newins etc.ppp/pap-secrets pap-secrets.example
newins etc.ppp/chap-secrets chap-secrets.example
insopts -o shill -g shill -m0644
doins etc.ppp/options
pamd_mimic_system ppp auth account session
local PLUGINS_DIR="/usr/$(get_libdir)/pppd/${PV}"
# closing " for syntax coloring
insinto "${PLUGINS_DIR}"
insopts -o shill -g shill -m0755
doins pppd/plugins/minconn.so
doins pppd/plugins/passprompt.so
doins pppd/plugins/passwordfd.so
doins pppd/plugins/winbind.so
doins pppd/plugins/rp-pppoe/rp-pppoe.so
doins pppd/plugins/pppol2tp/openl2tp.so
doins pppd/plugins/pppol2tp/pppol2tp.so
if use atm ; then
doins pppd/plugins/pppoatm/pppoatm.so
fi
if use dhcp ; then
doins pppd/plugins/dhcp/dhcpc.so
fi
if use radius ; then
doins pppd/plugins/radius/rad{ius,attr,realms}.so
#Copy radiusclient configuration files (#92878)
insinto /etc/ppp/radius
insopts -o shill -g shill -m0644
doins pppd/plugins/radius/etc/{dictionary*,issue,port-id-map,radiusclient.conf,realms,servers}
doman pppd/plugins/radius/pppd-rad{ius,attr}.8
fi
insinto /etc/modprobe.d
insopts -o shill -g shill -m0644
newins "${FILESDIR}/modules.ppp" ppp.conf
dodoc PLUGINS README* SETUP Changes-2.3 FAQ
dodoc "${FILESDIR}/README.mpls"
# This rules file is specific to CrOS and cannot be upstreamed, so must be
# carried forward.
udev_dorules "${FILESDIR}/99-pppd.rules"
dosbin scripts/p{on,off,log}
doman scripts/pon.1
# Adding misc. specialized scripts to doc dir
insinto /usr/share/doc/${PF}/scripts/chatchat
doins scripts/chatchat/*
insinto /usr/share/doc/${PF}/scripts
doins scripts/*
if use gtk ; then
dosbin contrib/pppgetpass/{pppgetpass.vt,pppgetpass.gtk}
newsbin contrib/pppgetpass/pppgetpass.sh pppgetpass
else
newsbin contrib/pppgetpass/pppgetpass.vt pppgetpass
fi
doman contrib/pppgetpass/pppgetpass.8
}
pkg_setup() {
enewuser shill
enewgroup shill
}
pkg_postinst() {
if linux-info_get_any_version && linux_config_src_exists ; then
echo
ewarn "If the following test report contains a missing kernel configuration option that you need,"
ewarn "you should reconfigure and rebuild your kernel before running pppd."
CONFIG_CHECK="~PPP ~PPP_ASYNC ~PPP_SYNC_TTY"
local ERROR_PPP="CONFIG_PPP:\t missing PPP support (REQUIRED)"
local ERROR_PPP_ASYNC="CONFIG_PPP_ASYNC:\t missing asynchronous serial line discipline (optional, but highly recommended)"
local WARNING_PPP_SYNC_TTY="CONFIG_PPP_SYNC_TTY:\t missing synchronous serial line discipline (optional; used by 'sync' pppd option)"
if use activefilter ; then
CONFIG_CHECK="${CONFIG_CHECK} ~PPP_FILTER"
local ERROR_PPP_FILTER="CONFIG_PPP_FILTER:\t missing PPP filtering support (REQUIRED)"
fi
CONFIG_CHECK="${CONFIG_CHECK} ~PPP_DEFLATE ~PPP_BSDCOMP ~PPP_MPPE"
local ERROR_PPP_DEFLATE="CONFIG_PPP_DEFLATE:\t missing Deflate compression (optional, but highly recommended)"
local ERROR_PPP_BSDCOMP="CONFIG_PPP_BSDCOMP:\t missing BSD-Compress compression (optional, but highly recommended)"
local WARNING_PPP_MPPE="CONFIG_PPP_MPPE:\t missing MPPE encryption (optional, mostly used by PPTP links)"
CONFIG_CHECK="${CONFIG_CHECK} ~PPPOE ~PACKET"
local WARNING_PPPOE="CONFIG_PPPOE:\t missing PPPoE support (optional, needed by rp-pppoe plugin)"
local WARNING_PACKET="CONFIG_PACKET:\t missing AF_PACKET support (optional, used by rp-pppoe and dhcpc plugins)"
if use atm ; then
CONFIG_CHECK="${CONFIG_CHECK} ~PPPOATM"
local WARNING_PPPOATM="CONFIG_PPPOATM:\t missing PPPoA support (optional, needed by pppoatm plugin)"
fi
check_extra_config
fi
# create *-secrets files if not exists
[ -f "${ROOT}/etc/ppp/pap-secrets" ] || \
cp -pP "${ROOT}/etc/ppp/pap-secrets.example" "${ROOT}/etc/ppp/pap-secrets"
[ -f "${ROOT}/etc/ppp/chap-secrets" ] || \
cp -pP "${ROOT}/etc/ppp/chap-secrets.example" "${ROOT}/etc/ppp/chap-secrets"
# lib name has changed
sed -i -e "s:^pppoe.so:rp-pppoe.so:" "${ROOT}/etc/ppp/options" || die
echo
elog "Pon, poff and plog scripts have been supplied for experienced users."
elog "Users needing particular scripts (ssh,rsh,etc.) should check out the"
elog "/usr/share/doc/${PF}/scripts directory."
}