Added ppp package.
This commit is contained in:
		
							parent
							
								
									ccfa890765
								
							
						
					
					
						commit
						15ee93b50f
					
				
							
								
								
									
										12
									
								
								net-dialup/ppp/Manifest
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								net-dialup/ppp/Manifest
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | |||
| AUX README.mpls 530 BLAKE2B 21d57668272eb02c994d0ae38a9895f095ad024bab1613995313480f5d314a5772c30bb0edb1032658993d897b58f5d2744abbc43e0416e63d8fe27dfc968819 SHA512 2b617365fce74cceeb14e53f476b454c4420273661050d25e1c524cf5d56a7554318a268f7b9ebb100592b61a01d274efaeed28abb9ca0adaeb71ef981201b36 | ||||
| AUX modules.ppp 299 BLAKE2B d5c0dcf135dd0a33288f27c95133d4dc980b84dc62bf8eca5b35040f4bfa5d0480cddc48263f390be8df0e0d8de704a62c490172b523612dd945a284e374372f SHA512 58bf5d6d286a08bd6dd595b39ee425efedd5745dddf33a9c90505891546eb46f4cf1306d83911bef61bc4611816aa0f6aef5d3e0f14c2f4ddd0a588780570041 | ||||
| AUX ppp-2.4.9-fix-MPPE-sstpc.patch 1008 BLAKE2B 255ac4374ef4845220c8c0709a0582fbc9dbb6c423d11b8132607c9bd39517e4e2c830a75ba35b27bba975c245f2e86d08bd9280b4ab0bc184e30db15179118d SHA512 cb16688634e4b6332b728511e0a70f80e7e29fdcc6b0d737745200381cc272daae80ddadd9f5fe4259113453596fd261f52249f80521b63506095a312c5bff33 | ||||
| AUX ppp-2.4.9-fix-clang-nested-functions.patch 2439 BLAKE2B 834d675ebcb4a3af7350d4206c546b89c92f914931db81e07e7997196d86dee6703260e9c603819d6fb72aec518dc5dbcc240f2a074043837d8d17356a483da3 SHA512 0d8faec40b0d3ea1a96a66bb4d96d129c7c0af14e76c222fc997c2eebeba80918a1681929a844d0d17713f124b862364ca1bf7cd70d2d7be46fb37458b3fb62d | ||||
| AUX ppp-2.4.9-fix-openssl-sysroot-clang.patch 377 BLAKE2B 9919669d6707394600c2b04f49dab212e220549395f34c52f641e6a87c2133eeaad00992fca5c3a9d84f60d7c17f1078aab78b8579906c93ee5cad4264a2569b SHA512 d816cbf65f1845851f8bd673fbe374987afbe6e3c0eb425455d0cc7269e96f5315caf1e38c320121650b088621c099c36f6b1c8d80ada0dbff07ab4e8151d42b | ||||
| AUX ppp-2.4.9-pppol2tp-ipv6.patch 1008 BLAKE2B 7c4ad1ce6ba6277c1d0fa8afa7491bdc3f0afba450c3d2ade39a9d0b555dd35e578abc5df24f7b0b011634bc020292ad6b2510ffbc8f03b1e3eabbf37cdb6e20 SHA512 071ef66e5ab9e08037100f2d6cdbdc452ea30d4a2241ef2abc2a7acc23ce21a5f90e5753a4790af5ed8e21baf976010a340ac4d4368adb8a9f5b42d52b519702 | ||||
| AUX pppd.tmpfiles 45 BLAKE2B 00daff2cb2f359640b41f8e13b08817754fa77e7a743910fb3e3cf100fffc77ea8bc38739c90123ac6bf44b417f25feedd0b2e2c91ead98b7affb7c92d22eed9 SHA512 8cb2aef7c17481f891cef981d47aceb879bbc64fe0766d193f23824484299414f0a576c45215ceaea18d39291b5ffe4c80aa4c00f0c68d88aeb924ace2ad5a8c | ||||
| DIST ppp-2.4.9-patches-03.tar.xz 18520 BLAKE2B b3da095672fa57727ba11a5dba761ea3f24ee330f27252f0379dab5761d5381809176faafed86d97a6b89cc8a4cb958baa07f4900e22fe6e76b6c852e0703f0c SHA512 9a035acf1915225340c12e6242f0c5db399b5f5970888d7f1799a5f125cf97b95d9fcb8c9aa2f6bd56c1544d2b10585f772d4fc1025002e3e8403011e3d2c029 | ||||
| DIST ppp-2.4.9.tar.gz 719904 BLAKE2B 7ba3eb8c98fec5599635dbd302399617e1075f3a1df090f1a94ce2bb8a5c7631e6eea82246adc33711aba5fe95e7ba7c982e2cbf1fb0d71e45f877d9b092ffb7 SHA512 c309f8f69f534c05547cd2f66dade0e0f198ea4c2928a7e899e660280786b3e965437a67b8c5bb81c59d0fa1818b4eb7b701d2dce015a420d380422d2bca4e1a | ||||
| DIST ppp-dhcpc.tgz 33497 BLAKE2B ca59130012f007cf45af6bcfa468c112b0d521c8b11f42d42c566dd9de55bd6d6f1b1ceb83cbae18cfe79cb5cb36ba6c6858a4718915acc6987295008aca53da SHA512 aeaf791b14f5a09c0e2079072a157e65132cbff46e608bc0724e6a5827a01da934f5006e2774eb7105f83e607a52cb4987238f4385cf6f5cc86cbe305a556738 | ||||
| EBUILD ppp-2.4.9-r9.ebuild 7860 BLAKE2B 96d3d3a4268c82a13e04b17f6f9989d5472487fde92d4294af996c2eb09e90c84fd97e3a53a5ab64c3fe31e7a365cb25a2fe1e79f427ea4ebf5a6a7e83407fdb SHA512 fb11d547ccbab9901bf16b81f207b104ba1376119c883d5e8081c3d8db49bd0c7c7d227f3a370dc46944afd82b037e420b4eea5335ec29be9bef6e57986ab7f2 | ||||
| MISC metadata.xml 1002 BLAKE2B 9ce1dcb685ed4f0d6dfe2e6c885b8feca8d81fd1fea5bde44a40900d65b2f9e9a45bd03f3708d4969c51880bb7ffb791bfbc972d4ec06a3124c4215e2b66424b SHA512 cdfa0b69fab5a530b36093bc84c352da1f8acbdf3d31e2b9a4d58bde7dc7bbbce9c54000d9f874eac2ddcc803bafc89ea2a74b03cac23dca295815ece6cb2157 | ||||
							
								
								
									
										15
									
								
								net-dialup/ppp/files/README.mpls
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										15
									
								
								net-dialup/ppp/files/README.mpls
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,15 @@ | |||
| MPLS consists of 3 components: | ||||
| 1. MPLS forwarding | ||||
| 2. MPLS signalling | ||||
| 3. Mapping layer 3 traffic onto MPLS LSPs | ||||
| 
 | ||||
| The document mpls-forwarding basics explains item 1. | ||||
| 
 | ||||
| Examples of MPLS signalling protocols are: RSVP-TE LDP and CR-LDP. | ||||
| The package ldp-portable is an implementation of LDP and contains more | ||||
| information about LDP based MPLS signalling. | ||||
| 
 | ||||
| Mapping of layer 3 traffic to MPLS LSPs is accomplised in a couple of | ||||
| different ways. | ||||
| -Per FEC where FEC is an entry in the routing table | ||||
| -Virtual interface that represents an LSP | ||||
							
								
								
									
										10
									
								
								net-dialup/ppp/files/modules.ppp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										10
									
								
								net-dialup/ppp/files/modules.ppp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,10 @@ | |||
| alias char-major-108	ppp_generic | ||||
| alias /dev/ppp		ppp_generic | ||||
| alias tty-ldisc-3	ppp_async | ||||
| alias tty-ldisc-13	n_hdlc | ||||
| alias tty-ldisc-14	ppp_synctty | ||||
| alias ppp-compress-18	ppp_mppe | ||||
| alias ppp-compress-21	bsd_comp | ||||
| alias ppp-compress-24	ppp_deflate | ||||
| alias ppp-compress-26	ppp_deflate | ||||
| alias net-pf-24		pppoe | ||||
							
								
								
									
										25
									
								
								net-dialup/ppp/files/ppp-2.4.9-fix-MPPE-sstpc.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										25
									
								
								net-dialup/ppp/files/ppp-2.4.9-fix-MPPE-sstpc.patch
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,25 @@ | |||
| https://github.com/ppp-project/ppp/commit/d7e62a8499c4032d79e05afbd8fd3efd51c5b148 | ||||
| https://bugs.launchpad.net/ubuntu/+source/ppp/+bug/1958196 | ||||
| 
 | ||||
| From: =?UTF-8?q?Eivind=20N=C3=A6ss?= <eivnaes@yahoo.com> | ||||
| Date: Thu, 3 Feb 2022 14:28:22 -0800 | ||||
| Subject: [PATCH] pppd/eap: Fix bug causing incorrect response length (#334) | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
| 
 | ||||
| Need to update the esp->ea_client.ea_namelen variable. A plugin can override the | ||||
| name of the user, and the variable is passed onto the eap_chap2_response generating | ||||
| the wrong response length. | ||||
| 
 | ||||
| Signed-off-by: Eivind Næss <eivnaes@yahoo.com> | ||||
| --- a/pppd/eap.c
 | ||||
| +++ b/pppd/eap.c
 | ||||
| @@ -2182,6 +2182,7 @@ eap_request(eap_state *esp, u_char *inp, int id, int len)
 | ||||
|  		    eap_send_nak(esp, id, EAPT_SRP); | ||||
|  		    break; | ||||
|  		} | ||||
| +		esp->es_client.ea_namelen = strlen(esp->es_client.ea_name);
 | ||||
|   | ||||
|  		/* Create the MSCHAPv2 response (and add to cache) */ | ||||
|  		unsigned char response[MS_CHAP2_RESPONSE_LEN+1]; // VLEN + VALUE | ||||
|  | @ -0,0 +1,65 @@ | |||
| https://github.com/ppp-project/ppp/commit/6e6a48fe628b76ec368277fd52685428e3dc8766 | ||||
| https://bugs.gentoo.org/831305 | ||||
| 
 | ||||
| From: =?UTF-8?q?Eivind=20N=C3=A6ss?= <eivnaes@yahoo.com> | ||||
| Date: Sun, 11 Jul 2021 14:36:44 -0700 | ||||
| Subject: [PATCH] Compiling with clang encounters an error in eap-tls.c | ||||
| MIME-Version: 1.0 | ||||
| Content-Type: text/plain; charset=UTF-8 | ||||
| Content-Transfer-Encoding: 8bit | ||||
| 
 | ||||
| This moves the inline functions to outside the function and declares them static. | ||||
| 
 | ||||
| Signed-off-by: Eivind Næss <eivnaes@yahoo.com> | ||||
| --- a/pppd/eap-tls.c
 | ||||
| +++ b/pppd/eap-tls.c
 | ||||
| @@ -285,6 +285,23 @@ ENGINE *eaptls_ssl_load_engine( char *engine_name )
 | ||||
|  #endif | ||||
|   | ||||
|   | ||||
| +#ifndef OPENSSL_NO_ENGINE
 | ||||
| +static int eaptls_UI_writer(UI *ui, UI_STRING *uis)
 | ||||
| +{
 | ||||
| +    PW_CB_DATA* cb_data = (PW_CB_DATA*)UI_get0_user_data(ui);
 | ||||
| +    UI_set_result(ui, uis, cb_data->password);
 | ||||
| +    return 1;
 | ||||
| +}
 | ||||
| +
 | ||||
| +static int eaptls_UI_stub(UI* ui) {
 | ||||
| +    return 1;
 | ||||
| +}
 | ||||
| +
 | ||||
| +static int eaptls_UI_reader(UI *ui, UI_STRING *uis) {
 | ||||
| +    return 1;
 | ||||
| +}
 | ||||
| +#endif
 | ||||
| +
 | ||||
|  /* | ||||
|   * Initialize the SSL stacks and tests if certificates, key and crl | ||||
|   * for client or server use can be loaded. | ||||
| @@ -578,20 +595,11 @@ SSL_CTX *eaptls_init_ssl(int init_server, char *cacertfile, char *capath,
 | ||||
|          { | ||||
|              UI_METHOD* transfer_pin = UI_create_method("transfer_pin"); | ||||
|   | ||||
| -            int writer (UI *ui, UI_STRING *uis)
 | ||||
| -            {
 | ||||
| -                PW_CB_DATA* cb_data = (PW_CB_DATA*)UI_get0_user_data(ui);
 | ||||
| -                UI_set_result(ui, uis, cb_data->password);
 | ||||
| -                return 1;
 | ||||
| -            };
 | ||||
| -            int stub (UI* ui) {return 1;};
 | ||||
| -            int stub_reader (UI *ui, UI_STRING *uis) {return 1;};
 | ||||
| -
 | ||||
| -            UI_method_set_writer(transfer_pin,  writer);
 | ||||
| -            UI_method_set_opener(transfer_pin,  stub);
 | ||||
| -            UI_method_set_closer(transfer_pin,  stub);
 | ||||
| -            UI_method_set_flusher(transfer_pin, stub);
 | ||||
| -            UI_method_set_reader(transfer_pin,  stub_reader);
 | ||||
| +            UI_method_set_writer(transfer_pin,  eaptls_UI_writer);
 | ||||
| +            UI_method_set_opener(transfer_pin,  eaptls_UI_stub);
 | ||||
| +            UI_method_set_closer(transfer_pin,  eaptls_UI_stub);
 | ||||
| +            UI_method_set_flusher(transfer_pin, eaptls_UI_stub);
 | ||||
| +            UI_method_set_reader(transfer_pin,  eaptls_UI_reader);
 | ||||
|   | ||||
|              dbglog( "Using our private key URI: '%s' in engine", privkeyfile ); | ||||
|              pkey = ENGINE_load_private_key(pkey_engine, privkeyfile, transfer_pin, &cb_data); | ||||
|  | @ -0,0 +1,14 @@ | |||
| https://bugs.gentoo.org/831305 | ||||
| 
 | ||||
| Upstream git has merged autotoolsification PR so no need for this. | ||||
| --- a/pppd/Makefile.linux
 | ||||
| +++ b/pppd/Makefile.linux
 | ||||
| @@ -155,7 +155,7 @@ endif
 | ||||
|   | ||||
|  ifdef NEEDDES | ||||
|  ifndef USE_CRYPT | ||||
| -CFLAGS   += -I$(shell $(CC) --print-sysroot)/usr/include/openssl
 | ||||
| +CFLAGS   += -I$(INSTROOT)/usr/include/openssl
 | ||||
|  NEEDCRYPTOLIB = y | ||||
|  else | ||||
|  CFLAGS   += -DUSE_CRYPT=1 | ||||
							
								
								
									
										28
									
								
								net-dialup/ppp/files/ppp-2.4.9-pppol2tp-ipv6.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								net-dialup/ppp/files/ppp-2.4.9-pppol2tp-ipv6.patch
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,28 @@ | |||
| https://bugs.gentoo.org/904740 | ||||
| https://github.com/ppp-project/ppp/pull/319 | ||||
| 
 | ||||
| From 44a70d6f9eb6d1843868da1d45de382134a03630 Mon Sep 17 00:00:00 2001 | ||||
| From: str8fast <52187302+str8fast@users.noreply.github.com> | ||||
| Date: Thu, 28 Oct 2021 14:55:56 +0000 | ||||
| Subject: [PATCH] pppol2tp.c add '#ifdef INET6' for optional ipv6 | ||||
| 
 | ||||
| Without it, l2tp daemon can't launch ppp, cuz undefined symbol ipv6_up_notifier. | ||||
| ---
 | ||||
|  pppd/plugins/pppol2tp/pppol2tp.c | 2 ++ | ||||
|  1 file changed, 2 insertions(+) | ||||
| 
 | ||||
| diff --git a/pppd/plugins/pppol2tp/pppol2tp.c b/pppd/plugins/pppol2tp/pppol2tp.c
 | ||||
| index ed2d7c79..c9902afe 100644
 | ||||
| --- a/pppd/plugins/pppol2tp/pppol2tp.c
 | ||||
| +++ b/pppd/plugins/pppol2tp/pppol2tp.c
 | ||||
| @@ -509,8 +509,10 @@ void plugin_init(void)
 | ||||
|  	 */ | ||||
|  	add_notifier(&ip_up_notifier, pppol2tp_ip_up, NULL); | ||||
|  	add_notifier(&ip_down_notifier, pppol2tp_ip_down, NULL); | ||||
| +#ifdef INET6
 | ||||
|  	add_notifier(&ipv6_up_notifier, pppol2tp_ip_up, NULL); | ||||
|  	add_notifier(&ipv6_down_notifier, pppol2tp_ip_down, NULL); | ||||
| +#endif
 | ||||
|  } | ||||
|   | ||||
|  struct channel pppol2tp_channel = { | ||||
							
								
								
									
										2
									
								
								net-dialup/ppp/files/pppd.tmpfiles
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								net-dialup/ppp/files/pppd.tmpfiles
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,2 @@ | |||
| d /run/pppd | ||||
| L /run/pppd/lock - - - - ../lock | ||||
							
								
								
									
										24
									
								
								net-dialup/ppp/metadata.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								net-dialup/ppp/metadata.xml
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,24 @@ | |||
| <?xml version="1.0" encoding="UTF-8"?> | ||||
| <!DOCTYPE pkgmetadata SYSTEM "https://www.gentoo.org/dtd/metadata.dtd"> | ||||
| <pkgmetadata> | ||||
| 	<maintainer type="project"> | ||||
| 		<email>base-system@gentoo.org</email> | ||||
| 		<name>Gentoo Base System</name> | ||||
| 	</maintainer> | ||||
| 	<use> | ||||
| 		<flag name="activefilter">Enables active filter support</flag> | ||||
| 		<flag name="dhcp">Installs PPP DHCP client plugin for IP address allocation | ||||
| 		by a DHCP server (see http://www.netservers.co.uk/gpl/)</flag> | ||||
| 		<flag name="eap-tls">Enables support for Extensible Authentication | ||||
| 		Protocol and Transport Level Security (see | ||||
| 		http://www.nikhef.nl/~janjust/ppp/index.html)</flag> | ||||
| 		<flag name="gtk">Installs GTK+ password prompting program that can be used | ||||
| 		by passprompt.so PPP plugin for reading the password from a X11 input | ||||
| 		terminal</flag> | ||||
| 		<flag name="radius">Enables RADIUS support</flag> | ||||
| 	</use> | ||||
| 	<upstream> | ||||
| 		<remote-id type="cpe">cpe:/a:samba:ppp</remote-id> | ||||
| 		<remote-id type="github">ppp-project/ppp</remote-id> | ||||
| 	</upstream> | ||||
| </pkgmetadata> | ||||
							
								
								
									
										257
									
								
								net-dialup/ppp/ppp-2.4.9-r9.ebuild
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										257
									
								
								net-dialup/ppp/ppp-2.4.9-r9.ebuild
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,257 @@ | |||
| # Copyright 1999-2023 Gentoo Authors | ||||
| # Distributed under the terms of the GNU General Public License v2 | ||||
| 
 | ||||
| EAPI=7 | ||||
| 
 | ||||
| inherit linux-info pam toolchain-funcs | ||||
| 
 | ||||
| PATCH_TARBALL_NAME="${PN}-2.4.9-patches-03" | ||||
| DESCRIPTION="Point-to-Point Protocol (PPP)" | ||||
| HOMEPAGE="https://ppp.samba.org/" | ||||
| SRC_URI="https://github.com/paulusmack/ppp/archive/${P}.tar.gz | ||||
| 	https://dev.gentoo.org/~polynomial-c/${PATCH_TARBALL_NAME}.tar.xz | ||||
| 	http://www.netservers.net.uk/gpl/ppp-dhcpc.tgz" | ||||
| 
 | ||||
| LICENSE="BSD GPL-2" | ||||
| SLOT="0/${PV}" | ||||
| KEYWORDS="~alpha amd64 arm arm64 ~hppa ~loong ~mips ppc ppc64 ~riscv ~s390 sparc x86" | ||||
| IUSE="activefilter atm dhcp +eap-tls gtk ipv6 pam radius systemd" | ||||
| 
 | ||||
| DEPEND=" | ||||
| 	dev-libs/openssl:0= | ||||
| 	virtual/libcrypt:= | ||||
| 	activefilter? ( net-libs/libpcap ) | ||||
| 	atm? ( net-dialup/linux-atm ) | ||||
| 	gtk? ( x11-libs/gtk+:2 ) | ||||
| 	pam? ( sys-libs/pam ) | ||||
| 	systemd? ( sys-apps/systemd ) | ||||
| " | ||||
| RDEPEND="${DEPEND} | ||||
| 	!<net-misc/netifrc-0.7.1-r2" | ||||
| BDEPEND="virtual/pkgconfig" | ||||
| PDEPEND="net-dialup/ppp-scripts" | ||||
| 
 | ||||
| S="${WORKDIR}/${PN}-${P}" | ||||
| 
 | ||||
| src_prepare() { | ||||
| 	mv "${WORKDIR}/dhcp" "${S}/pppd/plugins" || die | ||||
| 
 | ||||
| 	eapply "${WORKDIR}"/patches | ||||
| 	eapply "${FILESDIR}"/${P}-fix-MPPE-sstpc.patch | ||||
| 	eapply "${FILESDIR}"/${P}-fix-clang-nested-functions.patch | ||||
| 	eapply "${FILESDIR}"/${P}-fix-openssl-sysroot-clang.patch | ||||
| 	eapply "${FILESDIR}"/${P}-pppol2tp-ipv6.patch | ||||
| 
 | ||||
| 	#IPX Support is removed in kernel >= 5.15 | ||||
| 	sed -i 's/-DIPX_CHANGE //' pppd/Makefile.linux || die | ||||
| 
 | ||||
| 	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 "Disabling IPv6" | ||||
| 		sed -i '/^HAVE_INET6/s:^:#:' pppd/Makefile.linux || die | ||||
| 	else | ||||
| 		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 | ||||
| 
 | ||||
| 	if ! use eap-tls ; then | ||||
| 		einfo "Disabling EAP-TLS pppd auth support" | ||||
| 		sed -i '/^USE_EAPTLS=y/s:^:#:' pppd/Makefile.linux || die | ||||
| 		einfo "Disabling EAP-TLS plugin support" | ||||
| 		sed -i '/^CFLAGS += -DUSE_EAPTLS=1/s:^:#:' \ | ||||
| 			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 | ||||
| 
 | ||||
| 	if use systemd ; then | ||||
| 		einfo "Enabling systemd notification" | ||||
| 		sed '/SYSTEMD=/s@^#@@' -i pppd/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 | ||||
| 	emake CC="${CC}" COPTS="${CFLAGS} -D_GNU_SOURCE" | ||||
| 
 | ||||
| 	# 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 u+s-w /usr/sbin/pppd | ||||
| 
 | ||||
| 	# Install pppd header files | ||||
| 	emake -C pppd INSTROOT="${D}" install-devel | ||||
| 
 | ||||
| 	dosbin pppd/plugins/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 | ||||
| 
 | ||||
| 	if use pam; then | ||||
| 		pamd_mimic_system ppp auth account session | ||||
| 	fi | ||||
| 
 | ||||
| 	local PLUGINS_DIR="/usr/$(get_libdir)/pppd/${PV}" | ||||
| 	insinto "${PLUGINS_DIR}" | ||||
| 	insopts -m0755 | ||||
| 	doins pppd/plugins/minconn.so | ||||
| 	doins pppd/plugins/passprompt.so | ||||
| 	doins pppd/plugins/passwordfd.so | ||||
| 	doins pppd/plugins/winbind.so | ||||
| 	doins pppd/plugins/pppoe/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 -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 -m0644 | ||||
| 	newins "${FILESDIR}/modules.ppp" ppp.conf | ||||
| 
 | ||||
| 	dodoc PLUGINS README* SETUP Changes-2.3 FAQ | ||||
| 	dodoc "${FILESDIR}/README.mpls" | ||||
| 
 | ||||
| 	dosbin scripts/p{on,off,log} | ||||
| 	doman scripts/pon.1 | ||||
| 
 | ||||
| 	# Adding misc. specialized scripts to doc dir | ||||
| 	dodoc -r scripts | ||||
| 	docinto scripts | ||||
| 	dodoc -r scripts/chatchat | ||||
| 
 | ||||
| 	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 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 pppoe plugin)" | ||||
| 		local WARNING_PACKET="CONFIG_PACKET:\t missing AF_PACKET support (optional, used by 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 "${EROOT}/etc/ppp/pap-secrets" ]] || \ | ||||
| 		cp -pP "${EROOT}/etc/ppp/pap-secrets.example" "${EROOT}/etc/ppp/pap-secrets" | ||||
| 	[[ -f "${EROOT}/etc/ppp/chap-secrets" ]] || \ | ||||
| 		cp -pP "${EROOT}/etc/ppp/chap-secrets.example" "${EROOT}/etc/ppp/chap-secrets" | ||||
| 
 | ||||
| 	# lib name has changed | ||||
| 	sed -i -e "s:^rp-\(pppoe.so\):\1:" "${EROOT}/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." | ||||
| 
 | ||||
| 	if [[ -n ${REPLACING_VERSIONS} ]] ; then | ||||
| 		ewarn '"rp-pppoe.so" plugin has been renamed to "pppoe.so"' | ||||
| 	fi | ||||
| } | ||||
		Loading…
	
		Reference in a new issue