You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
86 lines
2.8 KiB
86 lines
2.8 KiB
8 years ago
|
# Copyright 1999-2016 Gentoo Foundation
|
||
|
# Distributed under the terms of the GNU General Public License v2
|
||
|
# $Id$
|
||
|
|
||
|
EAPI=6
|
||
|
|
||
|
inherit linux-mod
|
||
|
|
||
|
DESCRIPTION="Simple yet fast and modern VPN that utilizes state-of-the-art cryptography."
|
||
|
HOMEPAGE="https://www.wireguard.io/"
|
||
|
|
||
|
if [[ ${PV} == 9999 ]]; then
|
||
|
inherit git-r3
|
||
|
EGIT_REPO_URI="https://git.zx2c4.com/WireGuard"
|
||
|
KEYWORDS=""
|
||
|
else
|
||
|
SRC_URI="https://git.zx2c4.com/WireGuard/snapshot/WireGuard-experimental-${PV}.tar.xz"
|
||
|
S="${WORKDIR}/WireGuard-experimental-${PV}"
|
||
|
KEYWORDS="~amd64 ~x86 ~mips ~arm ~arm64"
|
||
|
fi
|
||
|
|
||
|
LICENSE="GPL-2"
|
||
|
SLOT="0"
|
||
8 years ago
|
IUSE="debug"
|
||
8 years ago
|
|
||
|
DEPEND="net-libs/libmnl"
|
||
|
RDEPEND="${DEPEND}"
|
||
|
|
||
|
MODULE_NAMES="wireguard(net:src)"
|
||
|
BUILD_PARAMS="KERNELDIR=${KERNEL_DIR} V=1"
|
||
8 years ago
|
CONFIG_CHECK="NET INET NET_UDP_TUNNEL NF_CONNTRACK NETFILTER_XT_MATCH_HASHLIMIT CRYPTO_BLKCIPHER ~PADATA ~IP6_NF_IPTABLES"
|
||
8 years ago
|
WARNING_PADATA="If you're running a multicore system you likely should enable CONFIG_PADATA for improved performance and parallel crypto."
|
||
8 years ago
|
WARNING_IP6_NF_IPTABLES="If your kernel has CONFIG_IPV6, you need CONFIG_IP6_NF_IPTABLES; otherwise WireGuard will not insert."
|
||
8 years ago
|
|
||
|
pkg_setup() {
|
||
|
linux-mod_pkg_setup
|
||
|
kernel_is -lt 4 1 0 && die "This version of ${PN} requires Linux >= 4.1"
|
||
|
}
|
||
|
|
||
|
src_compile() {
|
||
8 years ago
|
use debug && BUILD_PARAMS="CONFIG_WIREGUARD_DEBUG=y ${BUILD_PARAMS}"
|
||
8 years ago
|
linux-mod_src_compile
|
||
8 years ago
|
emake RUNSTATEDIR="${EPREFIX}/run" -C src/tools
|
||
8 years ago
|
}
|
||
|
|
||
|
src_install() {
|
||
|
dodoc README.md
|
||
8 years ago
|
dodoc -r contrib/examples
|
||
8 years ago
|
linux-mod_src_install
|
||
|
emake DESTDIR="${D}" PREFIX="${EPREFIX}/usr" -C src/tools install
|
||
8 years ago
|
insinto /$(get_libdir)/netifrc/net
|
||
|
newins "${FILESDIR}"/wireguard-openrc.sh wireguard.sh
|
||
8 years ago
|
}
|
||
|
|
||
|
pkg_postinst() {
|
||
|
linux-mod_pkg_postinst
|
||
|
ewarn
|
||
|
ewarn "This software is experimental and has not yet been released."
|
||
|
ewarn "As such, it may contain significant issues. Please do not file"
|
||
|
ewarn "bug reports with Gentoo, but rather direct them upstream to:"
|
||
|
ewarn
|
||
|
ewarn " team@wireguard.io security@wireguard.io"
|
||
|
ewarn
|
||
8 years ago
|
|
||
|
einfo
|
||
|
einfo "After installing WireGuard, if you'd like to try sending some packets through"
|
||
|
einfo "WireGuard, you may use, for testing purposes only, the insecure client.sh"
|
||
|
einfo "test example script:"
|
||
|
einfo
|
||
|
einfo " \$ bzcat /usr/share/doc/${PF}/examples/ncat-client-server/client.sh.bz2 | sudo bash -"
|
||
|
einfo
|
||
|
einfo "This will automatically setup interface wg0, through a very insecure transport"
|
||
|
einfo "that is only suitable for demonstration purposes. You can then try loading the"
|
||
|
einfo "hidden website or sending pings:"
|
||
|
einfo
|
||
|
einfo " \$ chromium http://192.168.4.1"
|
||
|
einfo " \$ ping 192.168.4.1"
|
||
|
einfo
|
||
|
einfo "If you'd like to redirect your internet traffic, you can run it with the"
|
||
|
einfo "\"default-route\" argument. You may not use this server for any abusive or illegal"
|
||
|
einfo "purposes. It is for quick testing only."
|
||
|
einfo
|
||
|
einfo "More info on getting started can be found at: https://www.wireguard.io/quickstart/"
|
||
|
einfo
|
||
8 years ago
|
}
|