nixfiles/hosts/storage/modules/rclone-serve.nix

69 lines
1.7 KiB
Nix
Raw Normal View History

2022-10-27 20:27:22 +01:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.rclone-serve;
makeNameSafe = name: builtins.replaceStrings [ "/" ] [ "-" ] name;
2022-11-03 06:44:02 +00:00
daemonService = serve_config:
lib.mkMerge [
{
wantedBy = [ "multi-user.target" ];
after = [ "network.target" ];
wants = [ "network.target" ];
serviceConfig = {
Type = "simple";
Restart = "on-failure";
RestartSec = "5s";
User = if serve_config.user != null then
"${serve_config.user}"
else
"root";
ExecStart =
"${pkgs.rclone}/bin/rclone serve ${serve_config.type} ${serve_config.remote} ${
lib.concatStringsSep " " serve_config.extraArgs
}";
};
}
serve_config.serviceConfig
];
2022-10-27 20:27:22 +01:00
in {
options = {
services.rclone-serve = {
enable = mkOption {
type = types.bool;
default = false;
};
remotes = mkOption {
type = types.listOf (types.submodule {
options = {
remote = mkOption { type = types.str; };
type = mkOption { type = types.str; };
user = mkOption { type = types.str; };
2022-11-03 06:44:02 +00:00
serviceConfig = mkOption { type = types.attrs; };
2022-10-27 20:27:22 +01:00
extraArgs = mkOption { type = types.listOf types.str; };
};
});
default = [ ];
};
};
};
config = mkMerge [
(mkIf (cfg.enable && cfg.remotes != [ ]) {
systemd.services = listToAttrs (map (remote: {
2022-11-03 06:44:02 +00:00
name = "rclone-serve-${makeNameSafe remote.type}-${
makeNameSafe remote.remote
2022-10-27 20:27:22 +01:00
}";
value = daemonService remote;
}) cfg.remotes);
})
];
}