automated garbage collection
This commit is contained in:
33
.gitea/workflows/cleanup-nixos.yml
Normal file
33
.gitea/workflows/cleanup-nixos.yml
Normal file
@@ -0,0 +1,33 @@
|
||||
name: Cleanup NixOS Generations
|
||||
on:
|
||||
schedule:
|
||||
- cron: '0 2 * * 0' # Every Sunday at 2am
|
||||
workflow_dispatch:
|
||||
|
||||
jobs:
|
||||
cleanup-generations:
|
||||
runs-on: [home-server]
|
||||
steps:
|
||||
- name: Cleanup old NixOS generations
|
||||
run: |
|
||||
echo "Deleting generations older than 7 days..."
|
||||
sudo nix-collect-garbage --delete-older-than 7d
|
||||
|
||||
notify-on-failure:
|
||||
runs-on: home-server
|
||||
needs: cleanup-generations
|
||||
if: failure()
|
||||
uses: ./.gitea/workflows/notify-ntfy.yml
|
||||
secrets:
|
||||
NTFY_CHANNEL: ${{ secrets.NTFY_CHANNEL }}
|
||||
with:
|
||||
title: "NixOS Cleanup Failed"
|
||||
message: |
|
||||
Failed to cleanup old NixOS generations
|
||||
Workflow: ${{ gitea.workflow }}
|
||||
Repository: ${{ gitea.repository }}
|
||||
Job: cleanup-generations
|
||||
Status: ${{ needs.cleanup-generations.result }}
|
||||
action_url: "https://git.alexmickelson.guru/${{ gitea.repository }}/actions/runs/${{ gitea.run_number }}"
|
||||
priority: "high"
|
||||
tags: "rotating_light,nixos"
|
||||
@@ -54,6 +54,18 @@
|
||||
|
||||
users.groups.gitea-runner = { };
|
||||
|
||||
security.sudo.extraRules = [
|
||||
{
|
||||
users = [ "gitea-runner" ];
|
||||
commands = [
|
||||
{
|
||||
command = "${pkgs.nix}/bin/nix-collect-garbage";
|
||||
options = [ "NOPASSWD" ];
|
||||
}
|
||||
];
|
||||
}
|
||||
];
|
||||
|
||||
system.activationScripts.zfs-delegate-gitea-runner = {
|
||||
text =
|
||||
let
|
||||
|
||||
Reference in New Issue
Block a user