nixpkgs/pkgs/tools/networking/cjdns/default.nix

42 lines
1.2 KiB
Nix
Raw Normal View History

{ lib, stdenv, fetchFromGitHub, nodejs, which, python27, util-linux, nixosTests }:
2020-06-24 22:50:35 -07:00
stdenv.mkDerivation rec {
pname = "cjdns";
2020-12-27 10:49:30 -08:00
version = "21.1";
src = fetchFromGitHub {
owner = "cjdelisle";
repo = "cjdns";
rev = "cjdns-v${version}";
2020-12-27 10:49:30 -08:00
sha256 = "NOmk+vMZ8i0E2MjrUzksk+tkJ9XVVNEXlE5OOTNa+Y0=";
};
buildInputs = [ which python27 nodejs ] ++
# for flock
2021-01-15 01:19:50 -08:00
lib.optional stdenv.isLinux util-linux;
2019-11-03 03:58:01 -08:00
CFLAGS = "-O2 -Wno-error=stringop-truncation";
buildPhase =
2021-01-15 01:19:50 -08:00
lib.optionalString stdenv.isAarch32 "Seccomp_NO=1 "
+ "bash do";
installPhase = ''
install -Dt "$out/bin/" cjdroute makekeys privatetopublic publictoip6
sed -i 's,/usr/bin/env node,'$(type -P node), \
$(find contrib -name "*.js")
sed -i 's,/usr/bin/env python,'$(type -P python), \
$(find contrib -type f)
mkdir -p $out/share/cjdns
cp -R contrib tools node_build node_modules $out/share/cjdns/
'';
2020-04-16 00:02:32 -07:00
passthru.tests.basic = nixosTests.cjdns;
meta = with lib; {
homepage = "https://github.com/cjdelisle/cjdns";
description = "Encrypted networking for regular people";
2020-12-27 10:49:30 -08:00
license = licenses.gpl3Plus;
2016-04-08 06:52:08 -07:00
maintainers = with maintainers; [ ehmry ];
platforms = platforms.linux;
};
}