36 lines
1.2 KiB
Nix
36 lines
1.2 KiB
Nix
{ stdenv, fetchFromGitHub, rustPlatform, darwin }:
|
|
|
|
rustPlatform.buildRustPackage rec {
|
|
pname = "boringtun";
|
|
# "boringtun" is still undergoing review for security concerns.
|
|
# The GitHub page does not show any release yet,
|
|
# use 20190407 as version number to indicate that it is an unstable version.
|
|
version = "20190407";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "cloudflare";
|
|
repo = pname;
|
|
rev = "b040eb4fd1591b1d5ceb07c6cbb0856553f50adc";
|
|
sha256 = "04i53dvxld2a0xzr0gfl895rcwfvisj1rfs7rl0444gml8s8xyb3";
|
|
};
|
|
|
|
cargoSha256 = "1gvmshwg9b486933vfgkg2r8nn6w6dyz42hqjy74p785fcg0v5hs";
|
|
|
|
# To prevent configuration phase error that is caused by
|
|
# lacking a new line in file ".cargo/config",
|
|
# we append a new line to the end of file.
|
|
preConfigure = "echo '' >> .cargo/config";
|
|
|
|
buildInputs = stdenv.lib.optional stdenv.isDarwin darwin.apple_sdk.frameworks.Security;
|
|
|
|
# Testing this project requires sudo, Docker and network access, etc.
|
|
doCheck = false;
|
|
|
|
meta = with stdenv.lib; {
|
|
description = "Userspace WireGuard® implementation in Rust";
|
|
homepage = https://github.com/cloudflare/boringtun;
|
|
license = licenses.bsd3;
|
|
maintainers = with maintainers; [ xrelkd ];
|
|
platforms = platforms.linux ++ platforms.darwin;
|
|
};
|
|
}
|