Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
130 lines
3.4 KiB
Nix
130 lines
3.4 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
rustPlatform,
|
|
fetchFromGitHub,
|
|
pkg-config,
|
|
protobuf,
|
|
makeWrapper,
|
|
git,
|
|
dbus,
|
|
libnftnl,
|
|
libmnl,
|
|
libwg,
|
|
darwin,
|
|
enableOpenvpn ? true,
|
|
openvpn-mullvad,
|
|
shadowsocks-rust,
|
|
installShellFiles,
|
|
writeShellScriptBin,
|
|
versionCheckHook,
|
|
}:
|
|
let
|
|
# NOTE(cole-h): This is necessary because wireguard-go-rs executes go in its build.rs (whose goal
|
|
# is to produce $OUT_DIR/libwg.a), and a mixed Rust-Go build is non-trivial (read: I didn't want
|
|
# to attempt it). So, we just fake the "go" binary and do what it would have done: put libwg.a
|
|
# under $OUT_DIR so that it can be linked against.
|
|
fakeGoCopyLibwg = writeShellScriptBin "go" ''
|
|
[ ! -e "$OUT_DIR"/libwg.a ] && cp ${libwg}/lib/libwg.a "$OUT_DIR"/libwg.a
|
|
'';
|
|
in
|
|
rustPlatform.buildRustPackage rec {
|
|
pname = "mullvad";
|
|
version = "2025.9";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "mullvad";
|
|
repo = "mullvadvpn-app";
|
|
tag = version;
|
|
fetchSubmodules = true;
|
|
hash = "sha256-BfWPFkNXGDV0ql2hBXh+3hjyn7+pUXL3XzH8w8aIfKw=";
|
|
};
|
|
|
|
cargoHash = "sha256-kgtjLdTkCnLk27gYEjovPv5k5eHOqQdL8iERKhVDKNQ=";
|
|
|
|
cargoBuildFlags = [
|
|
"-p mullvad-daemon --bin mullvad-daemon"
|
|
"-p mullvad-cli --bin mullvad"
|
|
"-p mullvad-setup --bin mullvad-setup"
|
|
"-p mullvad-problem-report --bin mullvad-problem-report"
|
|
"-p mullvad-exclude --bin mullvad-exclude"
|
|
"-p tunnel-obfuscation --bin tunnel-obfuscation"
|
|
"-p talpid-openvpn-plugin --lib"
|
|
];
|
|
|
|
checkFlags = [
|
|
"--skip=version_check"
|
|
"--skip=config_resolver::test"
|
|
];
|
|
|
|
nativeBuildInputs = [
|
|
pkg-config
|
|
protobuf
|
|
makeWrapper
|
|
git
|
|
installShellFiles
|
|
fakeGoCopyLibwg
|
|
];
|
|
|
|
buildInputs =
|
|
lib.optionals stdenv.hostPlatform.isLinux [
|
|
dbus.dev
|
|
libnftnl
|
|
libmnl
|
|
]
|
|
++ lib.optionals stdenv.hostPlatform.isDarwin [
|
|
darwin.libpcap
|
|
];
|
|
|
|
postInstall = ''
|
|
compdir=$(mktemp -d)
|
|
for shell in bash zsh fish; do
|
|
$out/bin/mullvad shell-completions $shell $compdir
|
|
done
|
|
installShellCompletion --cmd mullvad \
|
|
--bash $compdir/mullvad.bash \
|
|
--zsh $compdir/_mullvad \
|
|
--fish $compdir/mullvad.fish
|
|
'';
|
|
|
|
postFixup =
|
|
# Files necessary for OpenVPN tunnels to work.
|
|
lib.optionalString enableOpenvpn ''
|
|
mkdir -p $out/share/mullvad
|
|
cp dist-assets/ca.crt $out/share/mullvad
|
|
ln -s ${openvpn-mullvad}/bin/openvpn $out/share/mullvad
|
|
ln -s ${shadowsocks-rust}/bin/sslocal $out/share/mullvad
|
|
''
|
|
+
|
|
# Set the directory where Mullvad will look for its resources by default to
|
|
# `$out/share`, so that we can avoid putting the files in `$out/bin` --
|
|
# Mullvad defaults to looking inside the directory its binary is located in
|
|
# for its resources.
|
|
''
|
|
wrapProgram $out/bin/mullvad-daemon \
|
|
--set-default MULLVAD_RESOURCE_DIR "$out/share/mullvad"
|
|
'';
|
|
|
|
__darwinAllowLocalNetworking = true;
|
|
|
|
nativeInstallCheckInputs = [
|
|
versionCheckHook
|
|
];
|
|
versionCheckProgramArg = "--version";
|
|
doInstallCheck = true;
|
|
|
|
passthru = {
|
|
inherit libwg;
|
|
inherit openvpn-mullvad;
|
|
};
|
|
|
|
meta = {
|
|
description = "Mullvad VPN command-line client tools";
|
|
homepage = "https://github.com/mullvad/mullvadvpn-app";
|
|
changelog = "https://github.com/mullvad/mullvadvpn-app/blob/${version}/CHANGELOG.md";
|
|
license = lib.licenses.gpl3Only;
|
|
maintainers = with lib.maintainers; [ cole-h ];
|
|
mainProgram = "mullvad";
|
|
};
|
|
}
|