2021-01-17 03:51:22 +00:00
|
|
|
{ lib, stdenv, fetchurl, pkg-config, libevent, openssl, zlib, torsocks
|
2021-03-14 18:12:53 +00:00
|
|
|
, libseccomp, systemd, libcap, xz, zstd, scrypt, nixosTests
|
2020-09-11 06:46:59 +01:00
|
|
|
, writeShellScript
|
2018-03-04 22:11:09 +00:00
|
|
|
|
|
|
|
# for update.nix
|
|
|
|
, writeScript
|
|
|
|
, common-updater-scripts
|
|
|
|
, bash
|
|
|
|
, coreutils
|
|
|
|
, curl
|
|
|
|
, gnugrep
|
|
|
|
, gnupg
|
|
|
|
, gnused
|
|
|
|
, nix
|
2016-08-26 16:14:28 +01:00
|
|
|
}:
|
2020-09-11 06:46:59 +01:00
|
|
|
let
|
|
|
|
tor-client-auth-gen = writeShellScript "tor-client-auth-gen" ''
|
2021-01-15 09:19:50 +00:00
|
|
|
PATH="${lib.makeBinPath [coreutils gnugrep openssl]}"
|
2020-09-11 06:46:59 +01:00
|
|
|
pem="$(openssl genpkey -algorithm x25519)"
|
2010-05-16 17:23:32 +01:00
|
|
|
|
2020-09-11 06:46:59 +01:00
|
|
|
printf private_key=descriptor:x25519:
|
|
|
|
echo "$pem" | grep -v " PRIVATE KEY" |
|
|
|
|
base64 -d | tail --bytes=32 | base32 | tr -d =
|
|
|
|
|
|
|
|
printf public_key=descriptor:x25519:
|
|
|
|
echo "$pem" | openssl pkey -in /dev/stdin -pubout |
|
|
|
|
grep -v " PUBLIC KEY" |
|
|
|
|
base64 -d | tail --bytes=32 | base32 | tr -d =
|
|
|
|
'';
|
|
|
|
in
|
2010-05-24 22:28:54 +01:00
|
|
|
stdenv.mkDerivation rec {
|
2019-05-03 07:51:44 +01:00
|
|
|
pname = "tor";
|
2021-12-18 08:04:58 +00:00
|
|
|
version = "0.4.6.9";
|
2010-05-16 17:23:32 +01:00
|
|
|
|
|
|
|
src = fetchurl {
|
2019-05-03 07:51:44 +01:00
|
|
|
url = "https://dist.torproject.org/${pname}-${version}.tar.gz";
|
2021-12-18 08:04:58 +00:00
|
|
|
sha256 = "1ad99k4wysxrnlaprv7brxr2nc0h5zdnrh0rma10pqlck2037sf7";
|
2010-05-16 17:23:32 +01:00
|
|
|
};
|
|
|
|
|
2017-03-02 02:09:27 +00:00
|
|
|
outputs = [ "out" "geoip" ];
|
|
|
|
|
2021-01-17 03:51:22 +00:00
|
|
|
nativeBuildInputs = [ pkg-config ];
|
2021-03-14 18:12:53 +00:00
|
|
|
buildInputs = [ libevent openssl zlib xz zstd scrypt ] ++
|
2021-01-15 09:19:50 +00:00
|
|
|
lib.optionals stdenv.isLinux [ libseccomp systemd libcap ];
|
2010-05-24 22:28:43 +01:00
|
|
|
|
2020-02-19 08:03:39 +00:00
|
|
|
patches = [ ./disable-monotonic-timer-tests.patch ];
|
|
|
|
|
2020-05-04 13:22:33 +01:00
|
|
|
# cross compiles correctly but needs the following
|
2021-01-15 09:19:50 +00:00
|
|
|
configureFlags = lib.optional (stdenv.hostPlatform != stdenv.buildPlatform)
|
2020-05-04 13:22:33 +01:00
|
|
|
"--disable-tool-name-check";
|
|
|
|
|
2021-01-15 09:19:50 +00:00
|
|
|
NIX_CFLAGS_LINK = lib.optionalString stdenv.cc.isGNU "-lgcc_s";
|
2013-03-08 15:43:30 +00:00
|
|
|
|
2016-08-26 16:14:28 +01:00
|
|
|
postPatch = ''
|
2014-12-06 04:37:47 +00:00
|
|
|
substituteInPlace contrib/client-tools/torify \
|
|
|
|
--replace 'pathfind torsocks' true \
|
|
|
|
--replace 'exec torsocks' 'exec ${torsocks}/bin/torsocks'
|
2020-01-08 21:33:52 +00:00
|
|
|
|
|
|
|
patchShebangs ./scripts/maint/checkShellScripts.sh
|
2014-12-06 04:37:47 +00:00
|
|
|
'';
|
|
|
|
|
2018-09-05 02:13:16 +01:00
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2021-12-04 00:50:31 +00:00
|
|
|
# disable tests on aarch64-darwin, the following tests fail there:
|
|
|
|
# oom/circbuf: [forking]
|
|
|
|
# FAIL src/test/test_oom.c:187: assert(c1->marked_for_close)
|
|
|
|
# [circbuf FAILED]
|
|
|
|
# oom/streambuf: [forking]
|
|
|
|
# FAIL src/test/test_oom.c:287: assert(x_ OP_GE 500 - 5): 0 vs 495
|
|
|
|
# [streambuf FAILED]
|
|
|
|
doCheck = !(stdenv.isDarwin && stdenv.isAarch64);
|
2018-09-05 02:13:16 +01:00
|
|
|
|
2017-03-02 02:09:27 +00:00
|
|
|
postInstall = ''
|
|
|
|
mkdir -p $geoip/share/tor
|
|
|
|
mv $out/share/tor/geoip{,6} $geoip/share/tor
|
|
|
|
rm -rf $out/share/tor
|
2020-09-11 06:46:59 +01:00
|
|
|
ln -s ${tor-client-auth-gen} $out/bin/tor-client-auth-gen
|
2017-03-02 02:09:27 +00:00
|
|
|
'';
|
|
|
|
|
2020-07-28 14:16:37 +01:00
|
|
|
passthru = {
|
|
|
|
tests.tor = nixosTests.tor;
|
|
|
|
updateScript = import ./update.nix {
|
2021-01-27 05:44:43 +00:00
|
|
|
inherit lib;
|
2020-07-28 14:16:37 +01:00
|
|
|
inherit
|
|
|
|
writeScript
|
|
|
|
common-updater-scripts
|
|
|
|
bash
|
|
|
|
coreutils
|
|
|
|
curl
|
|
|
|
gnupg
|
|
|
|
gnugrep
|
|
|
|
gnused
|
|
|
|
nix
|
|
|
|
;
|
|
|
|
};
|
2018-03-04 22:11:09 +00:00
|
|
|
};
|
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2020-03-26 03:32:21 +00:00
|
|
|
homepage = "https://www.torproject.org/";
|
2020-04-01 02:11:51 +01:00
|
|
|
repositories.git = "https://git.torproject.org/git/tor";
|
2016-04-30 17:11:06 +01:00
|
|
|
description = "Anonymizing overlay network";
|
|
|
|
|
|
|
|
longDescription = ''
|
|
|
|
Tor helps improve your privacy by bouncing your communications around a
|
|
|
|
network of relays run by volunteers all around the world: it makes it
|
|
|
|
harder for somebody watching your Internet connection to learn what sites
|
|
|
|
you visit, and makes it harder for the sites you visit to track you. Tor
|
|
|
|
works with many of your existing applications, including web browsers,
|
|
|
|
instant messaging clients, remote login, and other applications based on
|
|
|
|
the TCP protocol.
|
2010-05-16 17:23:32 +01:00
|
|
|
'';
|
|
|
|
|
2016-04-30 17:11:06 +01:00
|
|
|
license = licenses.bsd3;
|
2010-05-24 22:28:54 +01:00
|
|
|
|
2016-04-30 17:11:06 +01:00
|
|
|
maintainers = with maintainers;
|
2021-12-18 09:25:46 +00:00
|
|
|
[ thoughtpolice joachifm prusnak ];
|
2016-04-30 17:11:06 +01:00
|
|
|
platforms = platforms.unix;
|
2010-05-24 22:28:54 +01:00
|
|
|
};
|
2010-05-16 17:23:32 +01:00
|
|
|
}
|