depot/pkgs/tools/networking/wg-netmanager/default.nix
Luke Granger-Brown 57725ef3ec Squashed 'third_party/nixpkgs/' content from commit 76612b17c0ce
git-subtree-dir: third_party/nixpkgs
git-subtree-split: 76612b17c0ce71689921ca12d9ffdc9c23ce40b2
2024-11-10 23:59:47 +00:00

36 lines
1.3 KiB
Nix

{ lib, stdenv, fetchFromGitHub, rustPlatform, Security }:
rustPlatform.buildRustPackage rec {
pname = "wg-netmanager";
version = "0.5.1";
src = fetchFromGitHub {
owner = "gin66";
repo = "wg_netmanager";
rev = "wg_netmanager-v${version}";
sha256 = "sha256-Mr4+TW1yOePEHa7puz6mTRJ514LGQeiEwPW3NKupV/M=";
};
cargoHash = "sha256-cOxkWMFPVmi+/BQWIvExzX5LDyC7C8kaTf5dGwfXj+s=";
buildInputs = lib.optional stdenv.hostPlatform.isDarwin Security;
# Test 01 tries to create a wireguard interface, which requires sudo.
doCheck = true;
checkFlags = [ "--skip" "device" ];
meta = with lib; {
description = "Wireguard network manager";
longDescription = ''
Wireguard network manager, written in rust, simplifies the setup of wireguard nodes,
identifies short connections between nodes residing in the same subnet,
identifies unreachable aka dead nodes and maintains the routes between all nodes automatically.
To achieve this, wireguard network manager needs to be running on each node.
'';
homepage = "https://github.com/gin66/wg_netmanager";
license = with licenses; [ mit asl20 bsd3 mpl20 ];
maintainers = with maintainers; [ gin66 ];
platforms = platforms.linux;
mainProgram = "wg_netmanager";
};
}