1
0
Fork 0

fix backupCfg option for arr module

This commit is contained in:
ibizaman 2023-11-16 23:48:19 -08:00 committed by Pierre Penninckx
parent 7e5a447257
commit 39c2c943a1
3 changed files with 159 additions and 8 deletions

View file

@ -104,6 +104,10 @@ Currently supported services and features are:
- [ ] Gitea to deploy
- [ ] Scrutiny to monitor hard drives health
- [ ] Export metrics to Prometheus.
- [x] Tests
- [x] Unit tests for modules.
- [x] Running in CI.
- [ ] Integration tests with real nodes.
## Usage

View file

@ -319,14 +319,16 @@ config.xml" templatedSettings) "${config.services.radarr.dataDir}/config.xml" (
shb.backup.instances =
let
backupConfig = name: _defaults: lib.mkIf (cfg.${name}.backupCfg != {}) {
${name} = {
sourceDirectories = [
config.shb.arr.${name}.dataDir
];
excludePatterns = [".db-shm" ".db-wal" ".mono"];
};
};
backupConfig = name: _defaults: lib.mkIf (cfg.${name}.backupCfg.enable or false) ({
${name} = (
cfg.${name}.backupCfg
// {
sourceDirectories = [
config.shb.arr.${name}.dataDir
];
excludePatterns = [".db-shm" ".db-wal" ".mono"];
});
});
in
lib.mkMerge (lib.mapAttrsToList backupConfig apps);
}

View file

@ -50,4 +50,149 @@ in
};
expr = testConfig {};
};
testRadarr = {
expected = {
systemd.services.radarr = {
preStart = "ln -fs /nix/store/z7gk6xfj51sr1n1bjj6lsadjrwjxzc5d--config.xml /var/lib/radarr/config.xml.template\nrm /var/lib/radarr/config.xml || :\nsed -e \"s|%APIKEY%|$(cat /run/radarr/apikey)|\" /var/lib/radarr/config.xml.template > /var/lib/radarr/config.xml\n";
serviceConfig = {
StateDirectoryMode = "0750";
UMask = "0027";
};
};
systemd.services.jackett = {};
systemd.tmpfiles.rules = [
"d '/var/lib/radarr' 0750 radarr radarr - -"
];
shb.backup = {};
shb.nginx.autheliaProtect = [
{
autheliaRules = [
{
domain = "radarr.example.com";
policy = "bypass";
resources = [
"^/api.*"
];
}
{
domain = "radarr.example.com";
policy = "two_factor";
subject = [
"group:arr_user"
];
}
];
domain = "example.com";
oidcEndpoint = "https://oidc.example.com";
subdomain = "radarr";
upstream = "http://127.0.0.1:7001";
}
];
users.users.radarr.extraGroups = [ "media" ];
users.groups.radarr.members = [ "backup" ];
services.bazarr = {};
services.jackett = {};
services.lidarr = {};
services.radarr = {
enable = true;
dataDir = "/var/lib/radarr";
user = "radarr";
group = "radarr";
};
services.readarr = {};
services.sonarr = {};
};
expr = testConfig {
services.radarr.user = "radarr";
services.radarr.group = "radarr";
shb.arr.radarr = {
subdomain = "radarr";
domain = "example.com";
enable = true;
oidcEndpoint = "https://oidc.example.com";
settings = {
APIKeyFile = "/run/radarr/apikey";
};
};
};
};
testRadarrWithBackup = {
expected = {
systemd.services.radarr = {
preStart = "ln -fs /nix/store/z7gk6xfj51sr1n1bjj6lsadjrwjxzc5d--config.xml /var/lib/radarr/config.xml.template\nrm /var/lib/radarr/config.xml || :\nsed -e \"s|%APIKEY%|$(cat /run/radarr/apikey)|\" /var/lib/radarr/config.xml.template > /var/lib/radarr/config.xml\n";
serviceConfig = {
StateDirectoryMode = "0750";
UMask = "0027";
};
};
systemd.services.jackett = {};
systemd.tmpfiles.rules = [
"d '/var/lib/radarr' 0750 radarr radarr - -"
];
shb.backup.instances = {
radarr = {
enable = true;
sourceDirectories = [ "/var/lib/radarr" ];
excludePatterns = [ ".db-shm" ".db-wal" ".mono" ];
};
};
shb.nginx.autheliaProtect = [
{
autheliaRules = [
{
domain = "radarr.example.com";
policy = "bypass";
resources = [
"^/api.*"
];
}
{
domain = "radarr.example.com";
policy = "two_factor";
subject = [
"group:arr_user"
];
}
];
domain = "example.com";
oidcEndpoint = "https://oidc.example.com";
subdomain = "radarr";
upstream = "http://127.0.0.1:7001";
}
];
users.users.radarr.extraGroups = [ "media" ];
users.groups.radarr.members = [ "backup" ];
services.bazarr = {};
services.jackett = {};
services.lidarr = {};
services.radarr = {
enable = true;
dataDir = "/var/lib/radarr";
user = "radarr";
group = "radarr";
};
services.readarr = {};
services.sonarr = {};
};
expr = testConfig {
services.radarr.user = "radarr";
services.radarr.group = "radarr";
shb.arr.radarr = {
subdomain = "radarr";
domain = "example.com";
enable = true;
oidcEndpoint = "https://oidc.example.com";
settings = {
APIKeyFile = "/run/radarr/apikey";
};
backupCfg = {
enable = true;
};
};
};
};
}