nixpkgs-suyu/nixos/modules/services/network-filesystems/u9fs.nix

79 lines
1.7 KiB
Nix
Raw Normal View History

2015-02-22 16:07:30 +01:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.u9fs;
in
{
options = {
services.u9fs = {
enable = mkOption {
type = types.bool;
default = false;
description = "Whether to run the u9fs 9P server for Unix.";
};
listenStreams = mkOption {
type = types.listOf types.str;
default = [ "564" ];
example = [ "192.168.16.1:564" ];
description = ''
Sockets to listen for clients on.
See <command>man 5 systemd.socket</command> for socket syntax.
'';
};
user = mkOption {
type = types.str;
default = "nobody";
description =
"User to run u9fs under.";
};
2015-02-22 16:07:30 +01:00
extraArgs = mkOption {
type = types.str;
default = "";
example = "-a none";
2015-02-22 16:07:30 +01:00
description =
''
Extra arguments to pass on invocation,
see <command>man 4 u9fs</command>
'';
};
};
};
config = mkIf cfg.enable {
systemd = {
sockets.u9fs = {
description = "U9fs Listening Socket";
wantedBy = [ "sockets.target" ];
after = [ "network.target" ];
2015-02-22 16:07:30 +01:00
inherit (cfg) listenStreams;
socketConfig.Accept = "yes";
};
services."u9fs@" = {
description = "9P Protocol Server";
reloadIfChanged = true;
requires = [ "u9fs.socket" ];
serviceConfig =
{ ExecStart = "-${pkgs.u9fs}/bin/u9fs ${cfg.extraArgs}";
2015-02-22 16:07:30 +01:00
StandardInput = "socket";
StandardError = "journal";
User = cfg.user;
AmbientCapabilities = "cap_setuid cap_setgid";
2015-02-22 16:07:30 +01:00
};
};
};
};
}