nixos/docuum: add module for docuum package
Co-Authored-By: Martin Weinelt <mweinelt@users.noreply.github.com>
This commit is contained in:
parent
a26fa45c80
commit
94d6d4e93a
|
@ -330,6 +330,7 @@
|
||||||
./security/systemd-confinement.nix
|
./security/systemd-confinement.nix
|
||||||
./security/tpm2.nix
|
./security/tpm2.nix
|
||||||
./security/wrappers/default.nix
|
./security/wrappers/default.nix
|
||||||
|
./services/admin/docuum.nix
|
||||||
./services/admin/meshcentral.nix
|
./services/admin/meshcentral.nix
|
||||||
./services/admin/oxidized.nix
|
./services/admin/oxidized.nix
|
||||||
./services/admin/pgadmin.nix
|
./services/admin/pgadmin.nix
|
||||||
|
|
45
nixos/modules/services/admin/docuum.nix
Normal file
45
nixos/modules/services/admin/docuum.nix
Normal file
|
@ -0,0 +1,45 @@
|
||||||
|
{ config, pkgs, lib, utils, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.services.docuum;
|
||||||
|
inherit (lib) mkIf mkEnableOption mkOption getExe types;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.services.docuum = {
|
||||||
|
enable = mkEnableOption "docuum daemon";
|
||||||
|
|
||||||
|
threshold = mkOption {
|
||||||
|
description = "Threshold for deletion in bytes, like `10 GB`, `10 GiB`, `10GB` or percentage-based thresholds like `50%`";
|
||||||
|
type = types.str;
|
||||||
|
default = "10 GB";
|
||||||
|
example = "50%";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = mkIf cfg.enable {
|
||||||
|
assertions = [
|
||||||
|
{
|
||||||
|
assertion = config.virtualisation.docker.enable;
|
||||||
|
message = "docuum requires docker on the host";
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
systemd.services.docuum = {
|
||||||
|
after = [ "docker.socket" ];
|
||||||
|
requires = [ "docker.socket" ];
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
path = [ config.virtualisation.docker.package ];
|
||||||
|
environment.HOME = "/var/lib/docuum";
|
||||||
|
|
||||||
|
serviceConfig = {
|
||||||
|
DynamicUser = true;
|
||||||
|
StateDirectory = "docuum";
|
||||||
|
SupplementaryGroups = [ "docker" ];
|
||||||
|
ExecStart = utils.escapeSystemdExecArgs [
|
||||||
|
(getExe pkgs.docuum)
|
||||||
|
"--threshold" cfg.threshold
|
||||||
|
];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user