nixpkgs/pkgs/applications/networking/p2p/gnunet/default.nix

73 lines
2.6 KiB
Nix
Raw Normal View History

{ stdenv, fetchurl, adns, curl, gettext, gmp, gnutls, libextractor
, libgcrypt, libgnurl, libidn, libmicrohttpd, libtool, libunistring
, makeWrapper, ncurses, pkgconfig, libxml2, sqlite, zlib
2020-08-04 22:48:46 +00:00
, libpulseaudio, libopus, libogg, jansson, libsodium }:
stdenv.mkDerivation rec {
2019-08-26 20:00:22 +00:00
pname = "gnunet";
2020-08-14 10:28:57 +00:00
version = "0.13.2";
src = fetchurl {
2019-08-26 20:00:22 +00:00
url = "mirror://gnu/gnunet/${pname}-${version}.tar.gz";
2020-08-14 10:28:57 +00:00
sha256 = "0b4a6bxwhpmj274d281vhny7i5rwydrdmab76xk6ji8vf0p705dn";
};
2019-08-26 20:00:22 +00:00
enableParallelBuilding = true;
nativeBuildInputs = [ pkgconfig libtool makeWrapper ];
buildInputs = [
2019-08-26 20:00:22 +00:00
adns curl gmp gnutls libextractor libgcrypt libgnurl libidn
2020-08-04 22:48:46 +00:00
libmicrohttpd libunistring libxml2 ncurses gettext libsodium
2019-08-26 20:00:22 +00:00
sqlite zlib libpulseaudio libopus libogg jansson
];
preConfigure = ''
# Brute force: since nix-worker chroots don't provide
# /etc/{resolv.conf,hosts}, replace all references to `localhost'
# by their IPv4 equivalent.
find . \( -name \*.c -or -name \*.conf \) | \
xargs sed -ie 's|\<localhost\>|127.0.0.1|g'
# Make sure the tests don't rely on `/tmp', for the sake of chroot
# builds.
find . \( -iname \*test\*.c -or -name \*.conf \) | \
xargs sed -ie "s|/tmp|$TMPDIR|g"
2013-01-06 08:15:38 +00:00
sed -ie 's|@LDFLAGS@|@LDFLAGS@ $(Z_LIBS)|g' \
src/regex/Makefile.in \
src/fs/Makefile.in
'';
2019-08-26 20:00:22 +00:00
# unfortunately, there's still a few failures with impure tests
doCheck = false;
2019-08-26 20:00:22 +00:00
checkPhase = ''
export GNUNET_PREFIX="$out"
export PATH="$out/bin:$PATH"
make -k check
'';
meta = with stdenv.lib; {
description = "GNU's decentralized anonymous and censorship-resistant P2P framework";
longDescription = ''
GNUnet is a framework for secure peer-to-peer networking that
does not use any centralized or otherwise trusted services. A
first service implemented on top of the networking layer
allows anonymous censorship-resistant file-sharing. Anonymity
is provided by making messages originating from a peer
indistinguishable from messages that the peer is routing. All
peers act as routers and use link-encrypted connections with
stable bandwidth utilization to communicate with each other.
GNUnet uses a simple, excess-based economic model to allocate
resources. Peers in GNUnet monitor each others behavior with
respect to resource usage; peers that contribute to the
network are rewarded with better service.
'';
homepage = "https://gnunet.org/";
2019-12-23 17:13:49 +00:00
license = licenses.agpl3Plus;
2020-08-04 22:48:46 +00:00
maintainers = with maintainers; [ pstn vrthra ];
platforms = platforms.gnu ++ platforms.linux;
};
}