diff options
Diffstat (limited to 'net-vpn/i2pd')
-rw-r--r-- | net-vpn/i2pd/i2pd-scm.ebuild | 86 |
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 } |