{ pkgs, ... }: { services.gitolite = { enable = true; user = "git"; group = "git"; adminPubkey = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIDi7GGOGVj1Y5Sc1EW6zEdrp78dS6hvmS348pqu9dUsB openpgp:0x6BE7BD6F"; extraGitoliteRc = '' $RC{UMASK} = 0027; $RC{GIT_CONFIG_KEYS} = '.*'; $RC{ROLES}{OWNERS} = 1; $RC{OWNER_ROLENAME} = 'OWNERS'; push(@{$RC{ENABLE}}, 'D'); # push(@{$RC{ENABLE}}, 'set-default-roles'); # push(@{$RC{ENABLE}}, 'create'); # push(@{$RC{ENABLE}}, 'fork'); ''; }; environment.persistence."/persist".directories = [ "/var/lib/gitolite" ]; systemd.timers."gitolite-trash-cleanup" = { wantedBy = [ "timers.target" ]; timerConfig = { OnCalendar = "*-*-* 00:00:00"; Unit = "gitolite-trash-cleanup.service"; }; }; systemd.services."gitolite-trash-cleanup" = { script = '' set -euo pipefail if [ ! -d "Trash" ] ; then echo Trash directory is nonexistent! echo No operations to perform. Exiting. exit 0 fi match=$(find Trash -type d -regextype posix-extended -regex ".*/[0-9]{4}-[0-9]{2}-[0-9]{2}_[0-9]{2}:[0-9]{2}:[0-9]{2}$") processed_entry=0 removed_entry=0 for dir in $match do system_timestamp=$(date +%s) trash_timestamp=$(basename $dir | sed -e "s/_/ /g" | date -f - +%s) age=$(( $system_timestamp - $trash_timestamp )) # Wipe trashes older than 2w if [[ age -gt 1209600 ]] ; then echo "Removing '$dir' (age $age)" rm -rf $dir ((removed_entry+=1)) fi ((processed_entry+=1)) done echo "Directories that needs cleanup:" find Trash -type d -empty -print -delete echo "Cleaned empty directories." echo "Done! Removed $removed_entry/$processed_entry" ''; path = with pkgs; [ bash util-linux coreutils ]; serviceConfig = { Type = "oneshot"; User = "git"; WorkingDirectory = "/var/lib/gitolite/repositories"; }; }; }