summary refs log tree commit diff
path: root/pkgs/tools/networking/nat-traverse/default.nix
blob: e3bf3391f21e83cc45af4301a5db23ea030258b3 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
{ stdenv, fetchurl, perl }:

stdenv.mkDerivation rec {
  pname = "nat-traverse";
  version = "0.7";

  src = fetchurl {
    url = "https://www.speicherleck.de/iblech/nat-traverse/nat-traverse-${version}.tar.bz2";
    sha256 = "0knwnqsjwv7sa5wjb863ghabs7s269a73qwkmxpsbngjw9s0j2ih";
  };

  nativeBuildInputs = [ perl ];

  installPhase = ''
    mkdir -p $out/bin $out/share/man/man1
    cp nat-traverse $out/bin
    gzip -c nat-traverse.1 > $out/share/man/man1/nat-traverse.1.gz
  '';

  meta = with stdenv.lib; {
    description = "NAT gateway traversal utility";
    longDescription = ''
      nat-traverse establishes direct connections between nodes which are
      behind NAT gateways, i.e. hosts which do not have public IP addresses.
      This is done using an UDP NAT traversal technique. Additionally, it's
      possible to setup a small VPN by using pppd on top of nat-traverse.

      nat-traverse does not need an external server on the Internet, and it
      isn't necessary to reconfigure the involved NAT gateways, either.
      nat-traverse works out-of-the-box.
    '';
    homepage = "https://www.speicherleck.de/iblech/nat-traverse/";
    license = licenses.gpl3Plus;
    platforms = platforms.all;
    maintainers = [ maintainers.iblech ];
  };
}