summaryrefslogtreecommitdiff
path: root/net-vpn/i2pd
diff options
context:
space:
mode:
Diffstat (limited to 'net-vpn/i2pd')
-rw-r--r--net-vpn/i2pd/i2pd-scm.ebuild86
1 files changed, 65 insertions, 21 deletions
diff --git a/net-vpn/i2pd/i2pd-scm.ebuild b/net-vpn/i2pd/i2pd-scm.ebuild
index 6a98866..e24f9fd 100644
--- a/net-vpn/i2pd/i2pd-scm.ebuild
+++ b/net-vpn/i2pd/i2pd-scm.ebuild
@@ -2,45 +2,89 @@
# Distributed under the terms of the GNU General Public License v2
# $Id$
-EAPI=5
-inherit eutils systemd user git-2
+EAPI=6
+inherit eutils systemd user git-r3 cmake-utils
DESCRIPTION="A C++ daemon for accessing the I2P anonymous network"
HOMEPAGE="https://github.com/PurpleI2P/i2pd"
SRC_URI=""
EGIT_REPO_URI="git://github.com/PurpleI2P/i2pd"
-LICENSE="GPL-2"
+LICENSE="BSD"
SLOT="0"
KEYWORDS=""
-IUSE=""
+IUSE="cpu_flags_x86_aes cpu_flags_x86_avx i2p-hardening libressl pch static -upnp"
-RDEPEND="
- >=dev-libs/boost-1.46[threads]
- dev-libs/crypto++"
+RDEPEND="!static? ( >=dev-libs/boost-1.49[threads]
+ !libressl? ( dev-libs/openssl:0[-bindist] )
+ libressl? ( dev-libs/libressl )
+ upnp? ( net-libs/miniupnpc )
+ )"
DEPEND="${RDEPEND}
- || ( >=sys-devel/gcc-4.6 >=sys-devel/clang-3.3 )"
+ static? ( >=dev-libs/boost-1.49[static-libs,threads]
+ !libressl? ( dev-libs/openssl:0[static-libs] )
+ libressl? ( dev-libs/libressl[static-libs] )
+ upnp? ( net-libs/miniupnpc[static-libs] ) )
+ i2p-hardening? ( >=sys-devel/gcc-4.7 )
+ || ( >=sys-devel/gcc-4.7 >=sys-devel/clang-3.3 )"
-I2PD_USER="${I2PD_USER:-i2pd}"
-I2PD_GROUP="${I2PD_GROUP:-i2pd}"
+I2PD_USER=i2pd
+I2PD_GROUP=i2pd
-#CMAKE_USE_DIR="${S}/build"
+CMAKE_USE_DIR="${S}/build"
+DOCS=( README.md contrib/i2pd.conf contrib/tunnels.conf )
-src_compile() {
- emake
+
+src_configure() {
+ mycmakeargs=(
+ -DWITH_AESNI=$(usex cpu_flags_x86_aes ON OFF)
+ -DWITH_HARDENING=$(usex i2p-hardening ON OFF)
+ -DWITH_PCH=$(usex pch ON OFF)
+ -DWITH_STATIC=$(usex static ON OFF)
+ -DWITH_UPNP=$(usex upnp ON OFF)
+ -DWITH_LIBRARY=ON
+ -DWITH_BINARY=ON
+ )
+ cmake-utils_src_configure ./build
}
src_install() {
- mkdir -p "${D}/usr/bin"
- cp "${S}/i2pd" "${D}/usr/bin"
- mkdir -p "${D}/var/lib/certificates/"
- cp -r "${S}/contrib/certificates/" "${D}/var/lib/certificates"
- dodoc ${S}/docs/*.md
- doman ${S}/debian/i2pd.1
-}
+ cmake-utils_src_install
+
+ # config
+ insinto /etc/i2pd
+ doins contrib/i2pd.conf
+ doins contrib/tunnels.conf
+
+ # grant i2pd group read and write access to config files
+ fowners "root:${I2PD_GROUP}" \
+ /etc/i2pd/i2pd.conf \
+ /etc/i2pd/tunnels.conf
+ fperms 660 \
+ /etc/i2pd/i2pd.conf \
+ /etc/i2pd/tunnels.conf
+ # working directory
+ keepdir /var/lib/i2pd
+ insinto /var/lib/i2pd
+ doins -r contrib/certificates
+ fowners "${I2PD_USER}:${I2PD_GROUP}" /var/lib/i2pd/
+ fperms 700 /var/lib/i2pd/
+
+ # add /var/lib/i2pd/certificates to CONFIG_PROTECT
+ doenvd "${FILESDIR}/99i2pd"
+}
pkg_setup() {
enewgroup "${I2PD_GROUP}"
- enewuser "${I2PD_USER}" -1 -1 "/var/lib/run/${PN}" "${I2PD_GROUP}"
+ enewuser "${I2PD_USER}" -1 -1 /var/lib/run/i2pd "${I2PD_GROUP}"
+}
+
+pkg_postinst() {
+ if [[ -f ${EROOT%/}/etc/i2pd/subscriptions.txt ]]; then
+ ewarn
+ ewarn "Configuration of the subscriptions has been moved from"
+ ewarn "subscriptions.txt to i2pd.conf. We recommend updating"
+ ewarn "i2pd.conf accordingly and deleting subscriptions.txt."
+ fi
}