summary refs log tree commit diff
path: root/nixos/modules/programs
diff options
context:
space:
mode:
authorJeremy Fleischman <jeremyfleischman@gmail.com>2023-07-08 17:16:17 -0700
committerJeremy Fleischman <jeremyfleischman@gmail.com>2023-10-13 00:32:15 -0700
commit7ee56994968e7c7d3e64b32974aecd3386ea8c68 (patch)
treee4f63b5601cb50ce8fdee3b5a0943806fa883eb7 /nixos/modules/programs
parent8b6e86b47378b36984bd7bc37e34126283c8355c (diff)
downloadnixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar.gz
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar.bz2
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar.lz
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar.xz
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.tar.zst
nixpkgs-7ee56994968e7c7d3e64b32974aecd3386ea8c68.zip
nixos/openvpn3: Add support for systemd-resolved
I noticed that openvpn3 is been clobbering my `/etc/resolv.conf` file. I
dug around a bit, and it turns out that upstream actually does have
support for systemd-resolved. I think it makes sense for us to
automatically enable that feature if the system is configured to use
systemd-resolved.

I opted to not change the default behavior of `pkgs.openvpn3`, but can
easily be convinced to change that if folks think I should.
Diffstat (limited to 'nixos/modules/programs')
-rw-r--r--nixos/modules/programs/openvpn3.nix20
1 files changed, 16 insertions, 4 deletions
diff --git a/nixos/modules/programs/openvpn3.nix b/nixos/modules/programs/openvpn3.nix
index df7e9ef22c1..37a1bfeb0c3 100644
--- a/nixos/modules/programs/openvpn3.nix
+++ b/nixos/modules/programs/openvpn3.nix
@@ -8,11 +8,23 @@ in
 {
   options.programs.openvpn3 = {
     enable = mkEnableOption (lib.mdDoc "the openvpn3 client");
+    package = mkOption {
+      type = types.package;
+      default = pkgs.openvpn3.override {
+        enableSystemdResolved = config.services.resolved.enable;
+      };
+      defaultText = literalExpression ''pkgs.openvpn3.override {
+        enableSystemdResolved = config.services.resolved.enable;
+      }'';
+      description = lib.mdDoc ''
+        Which package to use for `openvpn3`.
+      '';
+    };
   };
 
   config = mkIf cfg.enable {
-    services.dbus.packages = with pkgs; [
-      openvpn3
+    services.dbus.packages = [
+      cfg.package
     ];
 
     users.users.openvpn = {
@@ -25,8 +37,8 @@ in
       gid = config.ids.gids.openvpn;
     };
 
-    environment.systemPackages = with pkgs; [
-      openvpn3
+    environment.systemPackages = [
+      cfg.package
     ];
   };