seeks: nixos module

Changed files
+78
nixos
modules
misc
services
networking
+2
nixos/modules/misc/ids.nix
···
consul = 145;
mailpile = 146;
redmine = 147;
+
seeks = 148;
prosody = 148;
···
uhub = 142;
mailpile = 146;
redmine = 147;
+
seeks = 148;
prosody = 148;
+1
nixos/modules/module-list.nix
···
./services/networking/rpcbind.nix
./services/networking/sabnzbd.nix
./services/networking/searx.nix
+
./services/networking/seeks.nix
./services/networking/spiped.nix
./services/networking/ssh/lshd.nix
./services/networking/ssh/sshd.nix
+75
nixos/modules/services/networking/seeks.nix
···
+
{ config, lib, pkgs, ... }:
+
+
with lib;
+
+
let
+
+
cfg = config.services.seeks;
+
+
confDir = cfg.confDir;
+
+
seeks = pkgs.seeks.override { seeks_confDir = confDir; };
+
+
in
+
+
{
+
+
###### interface
+
+
options = {
+
+
services.seeks = {
+
+
enable = mkOption {
+
default = false;
+
type = types.bool;
+
description = "
+
Whether to enable the Seeks server.
+
";
+
};
+
+
confDir = mkOption {
+
default = "";
+
type = types.str;
+
description = "
+
The Seeks server configuration. If it is not specified,
+
a default configuration is used (${seeks}/etc/seeks).
+
";
+
};
+
+
};
+
+
};
+
+
+
###### implementation
+
+
config = mkIf config.services.seeks.enable {
+
+
users.extraUsers.seeks =
+
{ uid = config.ids.uids.seeks;
+
description = "Seeks user";
+
createHome = true;
+
home = "/var/lib/seeks";
+
};
+
+
users.extraGroups.seeks =
+
{ gid = config.ids.gids.seeks;
+
};
+
+
systemd.services.seeks =
+
{
+
description = "Seeks server, the p2p search engine.";
+
after = [ "network.target" ];
+
wantedBy = [ "multi-user.target" ];
+
serviceConfig = {
+
User = "seeks";
+
ExecStart = "${seeks}/bin/seeks";
+
};
+
};
+
+
environment.systemPackages = [ seeks ];
+
+
};
+
+
}