mirror of
https://github.com/SebastianStork/nixos-config.git
synced 2026-01-21 22:11:33 +01:00
Configure backups for forgejo
This commit is contained in:
parent
da9008c379
commit
b1507caac5
2 changed files with 56 additions and 0 deletions
|
|
@ -31,6 +31,7 @@
|
||||||
enable = true;
|
enable = true;
|
||||||
domain = "git.sstork.dev";
|
domain = "git.sstork.dev";
|
||||||
ssh.enable = true;
|
ssh.enable = true;
|
||||||
|
backups.enable = true;
|
||||||
};
|
};
|
||||||
|
|
||||||
caddy.virtualHosts = {
|
caddy.virtualHosts = {
|
||||||
|
|
|
||||||
55
modules/system/services/forgejo/backups.nix
Normal file
55
modules/system/services/forgejo/backups.nix
Normal file
|
|
@ -0,0 +1,55 @@
|
||||||
|
{
|
||||||
|
config,
|
||||||
|
pkgs,
|
||||||
|
lib,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
let
|
||||||
|
user = config.users.users.forgejo.name;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.custom.services.forgejo.backups.enable = lib.mkEnableOption "";
|
||||||
|
|
||||||
|
config = lib.mkIf config.custom.services.forgejo.backups.enable {
|
||||||
|
security.polkit = {
|
||||||
|
enable = true;
|
||||||
|
extraConfig =
|
||||||
|
let
|
||||||
|
service = "forgejo.service";
|
||||||
|
in
|
||||||
|
''
|
||||||
|
polkit.addRule(function(action, subject) {
|
||||||
|
if (action.id == "org.freedesktop.systemd1.manage-units" &&
|
||||||
|
action.lookup("unit") == "${service}" &&
|
||||||
|
subject.user == "${user}") {
|
||||||
|
return polkit.Result.YES;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
custom.services.resticBackup.forgejo = {
|
||||||
|
inherit user;
|
||||||
|
healthchecks.enable = true;
|
||||||
|
|
||||||
|
extraConfig = {
|
||||||
|
backupPrepareCommand = "${lib.getExe' pkgs.systemd "systemctl"} stop forgejo.service";
|
||||||
|
backupCleanupCommand = "${lib.getExe' pkgs.systemd "systemctl"} start forgejo.service";
|
||||||
|
paths = [ config.services.forgejo.stateDir ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
environment.systemPackages = [
|
||||||
|
(pkgs.writeShellApplication {
|
||||||
|
name = "forgejo-restore";
|
||||||
|
text = ''
|
||||||
|
sudo --user=${user} bash -c "
|
||||||
|
systemctl stop forgejo.service
|
||||||
|
restic-forgejo restore latest --target /
|
||||||
|
systemctl start forgejo.service
|
||||||
|
"
|
||||||
|
'';
|
||||||
|
})
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue