diff options
author | Alin Năstac <mrness@gentoo.org> | 2006-02-21 22:44:37 +0000 |
---|---|---|
committer | Alin Năstac <mrness@gentoo.org> | 2006-02-21 22:44:37 +0000 |
commit | 1de4b9da670fda6efc681f1586b0fbb8424b8f89 (patch) | |
tree | 816ae1a5697c53d000aac0ec3864c2a881b1dffc /net-dialup/ppp | |
parent | Let xkbcomp take care of creating /var/lib/xkb, as suggested in fd.o bug #5906. (diff) | |
download | gentoo-2-1de4b9da670fda6efc681f1586b0fbb8424b8f89.tar.gz gentoo-2-1de4b9da670fda6efc681f1586b0fbb8424b8f89.tar.bz2 gentoo-2-1de4b9da670fda6efc681f1586b0fbb8424b8f89.zip |
Wait for user scripts to finish at the end of PPP session (#122795).
(Portage version: 2.0.54)
Diffstat (limited to 'net-dialup/ppp')
-rw-r--r-- | net-dialup/ppp/ChangeLog | 7 | ||||
-rw-r--r-- | net-dialup/ppp/Manifest | 12 | ||||
-rw-r--r-- | net-dialup/ppp/files/digest-ppp-2.4.3-r11 | 3 | ||||
-rw-r--r-- | net-dialup/ppp/ppp-2.4.3-r11.ebuild | 318 |
4 files changed, 329 insertions, 11 deletions
diff --git a/net-dialup/ppp/ChangeLog b/net-dialup/ppp/ChangeLog index eb5284420915..9661524181a2 100644 --- a/net-dialup/ppp/ChangeLog +++ b/net-dialup/ppp/ChangeLog @@ -1,6 +1,11 @@ # ChangeLog for net-dialup/ppp # Copyright 2002-2006 Gentoo Foundation; Distributed under the GPL v2 -# $Header: /var/cvsroot/gentoo-x86/net-dialup/ppp/ChangeLog,v 1.134 2006/01/24 18:09:32 mrness Exp $ +# $Header: /var/cvsroot/gentoo-x86/net-dialup/ppp/ChangeLog,v 1.135 2006/02/21 22:44:37 mrness Exp $ + +*ppp-2.4.3-r11 (21 Feb 2006) + + 21 Feb 2006; Alin Nastac <mrness@gentoo.org> +ppp-2.4.3-r11.ebuild: + Wait for user scripts to finish at the end of PPP session (#122795). 23 Jan 2006; Alin Nastac <mrness@gentoo.org> files/modules.ppp, ppp-2.4.2-r10.ebuild, ppp-2.4.2-r15.ebuild, -ppp-2.4.3-r9.ebuild, diff --git a/net-dialup/ppp/Manifest b/net-dialup/ppp/Manifest index a1d5d5770bd2..a173fb65eaff 100644 --- a/net-dialup/ppp/Manifest +++ b/net-dialup/ppp/Manifest @@ -1,6 +1,3 @@ ------BEGIN PGP SIGNED MESSAGE----- -Hash: SHA1 - MD5 7aafa0983e0d3bca1c19df2716186ed6 ChangeLog 24041 MD5 1fd88dda7f4996799c69a9501d42cc23 files/README.mpls 530 MD5 140bc2a08334d3546f43259934da603e files/chat-default 347 @@ -8,6 +5,7 @@ MD5 c9117abf5fed623d5290779446e9855e files/confd.ppp0 2775 MD5 5402b1b60b30f4b5d8ade8a225451095 files/digest-ppp-2.4.2-r10 271 MD5 4d67dca76b0f8bae664bc4573222f349 files/digest-ppp-2.4.2-r15 271 MD5 cc26261aec73c4d1bdee0592b13a96cc files/digest-ppp-2.4.3-r10 195 +MD5 f13a85c4677854146101e4b497c94208 files/digest-ppp-2.4.3-r11 195 MD5 5a554e2a04b9e11bb5bea839213bf97c files/ip-down 931 MD5 6b7aff8114e83512b42ff1be3b1c2462 files/ip-down.baselayout 990 MD5 341c2661a11f00fdd1043a4d4e82977e files/ip-up 1083 @@ -25,10 +23,4 @@ MD5 e6fdfdc4317d7fe324c50bd0477ca3f8 metadata.xml 295 MD5 aa48e6320cfa9b25e6ffbb743aa1c343 ppp-2.4.2-r10.ebuild 6730 MD5 e09fd0128344ae0a0cc4da422f9975d0 ppp-2.4.2-r15.ebuild 7752 MD5 095515a95270f30bdd6434674b304b72 ppp-2.4.3-r10.ebuild 10119 ------BEGIN PGP SIGNATURE----- -Version: GnuPG v1.4.2 (GNU/Linux) - -iD8DBQFD45FFjG8pv1lIUX4RAioRAKCwiwkhq1fMfYoCtk4H4kIPDgKXqQCfTyPW -jfIawjG0mLyEDSzhRn8j/Ug= -=Nq1z ------END PGP SIGNATURE----- +MD5 233926eb61c77f46778c32458409115c ppp-2.4.3-r11.ebuild 10164 diff --git a/net-dialup/ppp/files/digest-ppp-2.4.3-r11 b/net-dialup/ppp/files/digest-ppp-2.4.3-r11 new file mode 100644 index 000000000000..90ed7a7cef1a --- /dev/null +++ b/net-dialup/ppp/files/digest-ppp-2.4.3-r11 @@ -0,0 +1,3 @@ +MD5 ec913855eb07eeb2f41099bfbcc255ab ppp-2.4.3-patches-20060221.tar.gz 55775 +MD5 848f6c3cafeb6074ffeb293c3af79b7c ppp-2.4.3.tar.gz 688092 +MD5 9d2f3febf510c5b0cbb4dacba713a217 ppp-dhcpc.tgz 33497 diff --git a/net-dialup/ppp/ppp-2.4.3-r11.ebuild b/net-dialup/ppp/ppp-2.4.3-r11.ebuild new file mode 100644 index 000000000000..c6d9d3245197 --- /dev/null +++ b/net-dialup/ppp/ppp-2.4.3-r11.ebuild @@ -0,0 +1,318 @@ +# Copyright 1999-2006 Gentoo Foundation +# Distributed under the terms of the GNU General Public License v2 +# $Header: /var/cvsroot/gentoo-x86/net-dialup/ppp/ppp-2.4.3-r11.ebuild,v 1.1 2006/02/21 22:44:37 mrness Exp $ + +inherit eutils flag-o-matic toolchain-funcs linux-info + +DESCRIPTION="Point-to-Point Protocol (PPP)" +HOMEPAGE="http://www.samba.org/ppp" +SRC_URI="ftp://ftp.samba.org/pub/ppp/${P}.tar.gz + mirror://gentoo/${P}-patches-20060221.tar.gz + dhcp? ( http://www.netservers.co.uk/gpl/ppp-dhcpc.tgz )" + +LICENSE="BSD GPL-2" +SLOT="0" +KEYWORDS="~alpha ~amd64 ~arm ~hppa ~ia64 ~mips ~ppc ~ppc64 ~sparc ~x86" +IUSE="activefilter atm dhcp eap-tls gtk ipv6 mppe-mppc pam radius" + +RDEPEND="virtual/libc + activefilter? ( >=virtual/libpcap-0.9.3 ) + atm? ( net-dialup/linux-atm ) + pam? ( sys-libs/pam ) + gtk? ( =x11-libs/gtk+-1* ) + eap-tls? ( net-misc/curl >=dev-libs/openssl-0.9.7 )" +DEPEND="${RDEPEND} + >=sys-apps/sed-4" + +pkg_setup() { + if use mppe-mppc; then + echo + ewarn "The mppe-mppc flag overwrites the pppd native MPPE support with MPPE-MPPC" + ewarn "patch developed by Jan Dubiec." + ewarn "The resulted pppd will work only with patched kernels with version <= 2.6.14." + einfo "You could obtain the kernel patch from MPPE-MPPC homepage:" + einfo " http://mppe-mppc.alphacron.de/" + ewarn "CAUTION: MPPC is a U.S. patented algorithm!" + ewarn "Ask yourself if you really need it and, if you do, consult your lawyer first." + ebeep + fi + + if has_version "<${CATEGORY}/${PF}"; then + local files="" + [ -f "${ROOT}/etc/conf.d/net.ppp0" ] && files=( "${ROOT}/etc/conf.d/net.ppp0" ) + if [ -f "${ROOT}/etc/init.d/net.ppp0" ]; then + local x y + x=$(<"${ROOT}/etc/init.d/net.ppp0") + y=$(<"${ROOT}/etc/init.d/net.lo") + #It should be symlink to net.lo or at least have the same content + if [ "$x" != "$y" ] ; then + files=( ${files[@]} "${ROOT}/etc/init.d/net.ppp0" ) + fi + fi + + if [[ -n "${files[@]}" ]]; then + local f + einfo "Gentoo is moving toward common configuration file for all network" + einfo "interfaces. Thus starting from >=ppp-2.4.3-r10 the following files" + einfo "are obsoleted and should be removed to avoid future confusion:" + for f in ${files[@]} ; do + eerror " ${f//\/\///} - conflict with baselayout" + done + for f in chat-default options-pppoe options-pptp ; do + f="${ROOT}/etc/ppp/${f}" + if [ -f "${f}" ] ; then + ewarn " ${f//\/\///} - unused by this version" + files=( ${files[@]} "${f}" ) + fi + done + echo + einfo "If you use the old net.ppp0 script, you need to:" + einfo " - upgrade to >=sys-apps/baselayout-1.12.0_pre11" + einfo " - set ppp0 parameters in /etc/conf.d/net (see example file)" + einfo " - remove conflicting files" + einfo " - upgrade net-dialup/ppp" + echo + einfo "If you never used net.ppp0 script, just run the following commands:" + einfo " rm ${files[@]}" + einfo " emerge --resume" + die "Conflicts with baselayout support detected" + fi + fi +} + +src_unpack() { + unpack ${A} + cd ${S} + + epatch ${WORKDIR}/patch/ppp_flags.patch + epatch ${WORKDIR}/patch/mpls.patch + epatch ${WORKDIR}/patch/killaddr-smarter.patch + epatch ${WORKDIR}/patch/upstream-fixes.patch + epatch ${WORKDIR}/patch/rp-pppoe-any-interface.patch + epatch ${WORKDIR}/patch/wait-children.patch + + use eap-tls && { + # see http://eaptls.spe.net/index.html for more info + einfo "Enabling EAP-TLS support" + epatch ${WORKDIR}/patch/eaptls-0.7-gentoo.patch + use mppe-mppc || epatch ${WORKDIR}/patch/eaptls-mppe-0.7.patch + } + + use mppe-mppc && { + einfo "Enabling MPPE-MPPC support" + epatch ${WORKDIR}/patch/mppe-mppc-1.1.patch + use eap-tls && epatch ${WORKDIR}/patch/eaptls-mppe-0.7-with-mppc.patch + } + + use atm && { + einfo "Enabling PPPoATM support" + sed -i "s/^#HAVE_LIBATM=yes/HAVE_LIBATM=yes/" ${S}/pppd/plugins/pppoatm/Makefile.linux + } + + use activefilter || { + einfo "Disabling active filter" + sed -i "s/^FILTER=y/#FILTER=y/" pppd/Makefile.linux + } + + use pam && { + einfo "Enabling PAM" + sed -i "s/^#USE_PAM=y/USE_PAM=y/" pppd/Makefile.linux + } + + use ipv6 && { + einfo "Enabling IPv6" + sed -i "s/#HAVE_INET6/HAVE_INET6/" pppd/Makefile.linux + } + + einfo "Enabling CBCP" + sed -i "s/^#CBCP=y/CBCP=y/" ${S}/pppd/Makefile.linux + + use dhcp && { + # copy the ppp-dhcp plugin files + einfo "Copying ppp-dhcp plugin files..." + tar -xzf ${DISTDIR}/ppp-dhcpc.tgz -C ${S}/pppd/plugins/ + sed -i -e 's/SUBDIRS := rp-pppoe/SUBDIRS := rp-pppoe dhcp/' ${S}/pppd/plugins/Makefile.linux + sed -i -e "s/-O2/${CFLAGS} -fPIC/" ${S}/pppd/plugins/dhcp/Makefile.linux + epatch ${WORKDIR}/patch/dhcp-sys_error_to_strerror.patch + } + + # Set correct libdir + sed -i -e "s:/lib/pppd:/$(get_libdir)/pppd:" \ + ${S}/pppd/{pathnames.h,pppd.8} || die + + find ${S} -type f -name Makefile.linux \ + -exec sed -i -e '/^CC[[:space:]]*=/d' {} \; + + use radius && { + #set the right paths in radiusclient.conf + sed -i -e "s:/usr/local/etc:/etc:" \ + -e "s:/usr/local/sbin:/usr/sbin:" ${S}/pppd/plugins/radius/etc/radiusclient.conf + #set config dir to /etc/ppp/radius + sed -i -e "s:/etc/radiusclient:/etc/ppp/radius:g" \ + ${S}/pppd/plugins/radius/{*.8,*.c,*.h} \ + ${S}/pppd/plugins/radius/etc/* + } +} + +src_compile() { + export CC="$(tc-getCC)" + export AR="$(tc-getAR)" + append-ldflags $(bindnow-flags) + econf || die "configuration failed" + emake COPTS="${CFLAGS}" || die "compile failed" + + #build pppgetpass + cd contrib/pppgetpass + if use gtk; then + emake -f Makefile.linux || die "failed to build pppgetpass" + else + emake pppgetpass.vt || die "failed to build pppgetpass" + fi +} + +pkg_preinst() { + if use radius && [ -d ${ROOT}/etc/radiusclient ] && has_version "<${CATEGORY}/${PN}-2.4.3-r5"; then + ebegin "Copy /etc/radiusclient to /etc/ppp/radius" + cp -pPR ${ROOT}/etc/radiusclient ${ROOT}/etc/ppp/radius + eend $? + fi +} + +src_install() { + local y + for y in chat pppd pppdump pppstats + do + doman ${y}/${y}.8 + dosbin ${y}/${y} + done + chmod u+s-w ${D}/usr/sbin/pppd + + dosbin pppd/plugins/rp-pppoe/pppoe-discovery + + dodir /etc/ppp/peers + insinto /etc/ppp + insopts -m0600 + newins etc.ppp/pap-secrets pap-secrets.example + newins etc.ppp/chap-secrets chap-secrets.example + + insopts -m0644 + doins etc.ppp/options + + insopts -m0755 + newins ${FILESDIR}/ip-up.baselayout ip-up + newins ${FILESDIR}/ip-down.baselayout ip-down + + if use pam; then + insinto /etc/pam.d + insopts -m0644 + newins pppd/ppp.pam ppp || die "not found ppp.pam" + fi + + local PLUGINS_DIR=/usr/$(get_libdir)/pppd/$(awk -F '"' '/VERSION/ {print $2}' pppd/patchlevel.h) + #closing " for syntax coloring + dodir ${PLUGINS_DIR} + insinto ${PLUGINS_DIR} + insopts -m0755 + doins pppd/plugins/minconn.so || die "minconn.so not build" + doins pppd/plugins/passprompt.so || die "passprompt.so not build" + doins pppd/plugins/passwordfd.so || die "passwordfd.so not build" + doins pppd/plugins/winbind.so || die "winbind.so not build" + doins pppd/plugins/rp-pppoe/rp-pppoe.so || die "rp-pppoe.so not build" + if use atm; then + doins pppd/plugins/pppoatm/pppoatm.so || die "pppoatm.so not build" + fi + if use dhcp; then + doins pppd/plugins/dhcp/dhcpc.so || die "dhcpc.so not build" + fi + if use radius; then + doins pppd/plugins/radius/radius.so || die "radius.so not build" + doins pppd/plugins/radius/radattr.so || die "radattr.so not build" + doins pppd/plugins/radius/radrealms.so || die "radrealms.so not build" + + #Copy radiusclient configuration files (#92878) + insinto /etc/ppp/radius + insopts -m0644 + doins pppd/plugins/radius/etc/{dictionary*,issue,port-id-map,radiusclient.conf,realms,servers} + + doman pppd/plugins/radius/pppd-radius.8 + doman pppd/plugins/radius/pppd-radattr.8 + fi + + insinto /etc/modules.d + insopts -m0644 + newins ${FILESDIR}/modules.ppp ppp + if use mppe-mppc; then + sed -i -e 's/ppp_mppe/ppp_mppe_mppc/' ${D}/etc/modules.d/ppp + fi + + dodoc PLUGINS README* SETUP Changes-2.3 FAQ + dodoc ${FILESDIR}/README.mpls + + dosbin scripts/pon + dosbin scripts/poff + dosbin scripts/plog + doman scripts/pon.1 + + # Adding misc. specialized scripts to doc dir + dodir /usr/share/doc/${PF}/scripts/chatchat + 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_postinst() { + if get_version ; then + echo + ewarn "If any of the following kernel configuration options is missing," + ewarn "you should reconfigure and rebuild your kernel before running pppd." + CONFIG_CHECK="~PPP" + use activefilter && CONFIG_CHECK="${CONFIG_CHECK} ~PPP_FILTER" + CONFIG_CHECK="${CONFIG_CHECK} ~PPP_BSDCOMP ~PPP_DEFLATE" + check_extra_config + echo + fi + + if [ ! -e ${ROOT}/dev/.devfsd ] && [ ! -e ${ROOT}/dev/.udev ] && [ ! -e ${ROOT}/dev/ppp ]; then + mknod ${ROOT}/dev/ppp c 108 0 + fi + if [ "$ROOT" = "/" ]; then + /sbin/update-modules + 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 + + if use radius && has_version "<${CATEGORY}/${PN}-2.4.3-r5"; then + echo + ewarn "As of ${PN}-2.4.3-r5, the RADIUS configuration files have moved from" + ewarn " /etc/radiusclient to /etc/ppp/radius." + einfo "For your convenience, radiusclient directory was copied to the new location." + fi + + echo + einfo "Pon, poff and plog scripts have been supplied for experienced users." + einfo "Users needing particular scripts (ssh,rsh,etc.) should check out the" + einfo "/usr/share/doc/ppp*/scripts directory." + + echo + ewarn "The old /etc/init.d/net.ppp0 script has gone!" + einfo "The new way of handling PPP connections of any kind (PPPoE, PPPoA, etc)" + einfo "is through the baselayout's pppd net module." + einfo "Make sure you have a supported version of baselayout by running:" + einfo " emerge -u '>=sys-apps/baselayout-1.12.0_pre11'" +} |