2024-05-23 20:26:30 +00:00
|
|
|
{
|
|
|
|
|
lib,
|
|
|
|
|
config,
|
|
|
|
|
pkgs,
|
|
|
|
|
...
|
|
|
|
|
}:
|
|
|
|
|
with lib;
|
|
|
|
|
with lib.custom; let
|
|
|
|
|
cfg = config.services.vpn;
|
|
|
|
|
in {
|
|
|
|
|
options.services.vpn = with types; {
|
2024-05-23 21:24:09 +00:00
|
|
|
enable = mkBoolOpt false "Enable VPN service(s)";
|
|
|
|
|
|
|
|
|
|
enableMullvad = mkBoolOpt false "Enable Mullvad VPN Daemon";
|
2024-05-23 20:26:30 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
2024-05-23 21:24:09 +00:00
|
|
|
services.mullvad-vpn.enable = cfg.enableMullvad;
|
2024-05-23 20:26:30 +00:00
|
|
|
services.openvpn.servers = {
|
|
|
|
|
work = {
|
|
|
|
|
config = ''config /home/zack/Downloads/zachary_myers.ovpn'';
|
|
|
|
|
updateResolvConf = true;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
2024-05-23 21:24:09 +00:00
|
|
|
systemd.services."mullvad-daemon".postStart = let
|
|
|
|
|
mullvad = config.services.mullvad-vpn.package;
|
|
|
|
|
in
|
|
|
|
|
mkIf cfg.enableMullvad ''
|
|
|
|
|
while ! ${mullvad}/bin/mullvad status >/dev/null; do sleep 1; done
|
|
|
|
|
${mullvad}/bin/mullvad auto-connect set on
|
|
|
|
|
${mullvad}/bin/mullvad tunnel set ipv6 on
|
|
|
|
|
${mullvad}/bin/mullvad connect
|
|
|
|
|
'';
|
2024-05-23 20:26:30 +00:00
|
|
|
};
|
|
|
|
|
}
|