aboutsummaryrefslogtreecommitdiff
path: root/infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix
diff options
context:
space:
mode:
authorMx Kookie <kookie@spacekookie.de>2020-10-31 19:35:09 +0100
committerMx Kookie <kookie@spacekookie.de>2020-10-31 19:35:09 +0100
commitc4625b175f8200f643fd6e11010932ea44c78433 (patch)
treebce3f89888c8ac3991fa5569a878a9eab6801ccc /infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix
parent49f735974dd103039ddc4cb576bb76555164a9e7 (diff)
parentd661aa56a8843e991261510c1bb28fdc2f6975ae (diff)
Add 'infra/libkookie/' from commit 'd661aa56a8843e991261510c1bb28fdc2f6975ae'
git-subtree-dir: infra/libkookie git-subtree-mainline: 49f735974dd103039ddc4cb576bb76555164a9e7 git-subtree-split: d661aa56a8843e991261510c1bb28fdc2f6975ae
Diffstat (limited to 'infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix')
-rw-r--r--infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix113
1 files changed, 113 insertions, 0 deletions
diff --git a/infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix b/infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix
new file mode 100644
index 000000000000..ddcc0ed8f5a4
--- /dev/null
+++ b/infra/libkookie/nixpkgs/nixos/modules/tasks/filesystems/nfs.nix
@@ -0,0 +1,113 @@
+{ config, lib, pkgs, ... }:
+
+with lib;
+
+let
+
+ inInitrd = any (fs: fs == "nfs") config.boot.initrd.supportedFilesystems;
+
+ nfsStateDir = "/var/lib/nfs";
+
+ rpcMountpoint = "${nfsStateDir}/rpc_pipefs";
+
+ idmapdConfFile = pkgs.writeText "idmapd.conf" ''
+ [General]
+ Pipefs-Directory = ${rpcMountpoint}
+ ${optionalString (config.networking.domain != null)
+ "Domain = ${config.networking.domain}"}
+
+ [Mapping]
+ Nobody-User = nobody
+ Nobody-Group = nogroup
+
+ [Translation]
+ Method = nsswitch
+ '';
+
+ nfsConfFile = pkgs.writeText "nfs.conf" cfg.extraConfig;
+ requestKeyConfFile = pkgs.writeText "request-key.conf" ''
+ create id_resolver * * ${pkgs.nfs-utils}/bin/nfsidmap -t 600 %k %d
+ '';
+
+ cfg = config.services.nfs;
+
+in
+
+{
+ ###### interface
+
+ options = {
+ services.nfs = {
+ extraConfig = mkOption {
+ type = types.lines;
+ default = "";
+ description = ''
+ Extra nfs-utils configuration.
+ '';
+ };
+ };
+ };
+
+ ###### implementation
+
+ config = mkIf (any (fs: fs == "nfs" || fs == "nfs4") config.boot.supportedFilesystems) {
+
+ services.rpcbind.enable = true;
+
+ system.fsPackages = [ pkgs.nfs-utils ];
+
+ boot.initrd.kernelModules = mkIf inInitrd [ "nfs" ];
+
+ systemd.packages = [ pkgs.nfs-utils ];
+
+ environment.systemPackages = [ pkgs.keyutils ];
+
+ environment.etc = {
+ "idmapd.conf".source = idmapdConfFile;
+ "nfs.conf".source = nfsConfFile;
+ "request-key.conf".source = requestKeyConfFile;
+ };
+
+ systemd.services.nfs-blkmap =
+ { restartTriggers = [ nfsConfFile ];
+ };
+
+ systemd.targets.nfs-client =
+ { wantedBy = [ "multi-user.target" "remote-fs.target" ];
+ };
+
+ systemd.services.nfs-idmapd =
+ { restartTriggers = [ idmapdConfFile ];
+ };
+
+ systemd.services.nfs-mountd =
+ { restartTriggers = [ nfsConfFile ];
+ enable = mkDefault false;
+ };
+
+ systemd.services.nfs-server =
+ { restartTriggers = [ nfsConfFile ];
+ enable = mkDefault false;
+ };
+
+ systemd.services.auth-rpcgss-module =
+ {
+ unitConfig.ConditionPathExists = [ "" "/etc/krb5.keytab" ];
+ };
+
+ systemd.services.rpc-gssd =
+ { restartTriggers = [ nfsConfFile ];
+ unitConfig.ConditionPathExists = [ "" "/etc/krb5.keytab" ];
+ };
+
+ systemd.services.rpc-statd =
+ { restartTriggers = [ nfsConfFile ];
+
+ preStart =
+ ''
+ mkdir -p /var/lib/nfs/{sm,sm.bak}
+ '';
+ };
+
+ };
+}