add restic hook for gitea
This commit is contained in:
parent
91bd92045e
commit
d8ffc99fdd
49
roles/restic/files/hooks/gitea.sh
Normal file
49
roles/restic/files/hooks/gitea.sh
Normal file
@ -0,0 +1,49 @@
|
||||
#!/bin/bash
|
||||
|
||||
set -e
|
||||
|
||||
PATH="$PATH:/usr/local/bin:/usr/sbin:/sbin"
|
||||
|
||||
GITEA_USER=${GITEA_USER:-git}
|
||||
GITEA_CONFIG=${GITEA_CONFIG:-/etc/gitea/app.ini}
|
||||
GITEA_WORK_PATH=${GITEA_WORK_PATH:-/var/lib/gitea}
|
||||
GITEA_CUSTOM_PATH=${GITEA_CUSTOM_PATH:-$GITEA_WORK_PATH/custom}
|
||||
GITEA_BACKUP_PATH=${GITEA_BACKUP_PATH:-$GITEA_WORK_PATH/backup}
|
||||
GITEA_KEEP_DAYS=${GITEA_KEEP_DAYS:-7}
|
||||
|
||||
prereq() {
|
||||
if ! systemctl list-units --full --all | grep -Fq "gitea.service"; then
|
||||
printf "gitea.service unit does not exit\n"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
if (( EUID != 0 )); then
|
||||
printf "must be run as root\n"
|
||||
exit 1
|
||||
fi
|
||||
}
|
||||
|
||||
main() {
|
||||
prereq
|
||||
|
||||
if [ "$1" == "pre" ]; then
|
||||
pushd "$GITEA_BACKUP_PATH" > /dev/null || printf "could not chdir to %s\n" "$GITEA_BACKUP_PATH"
|
||||
printf "gitea dump started\n"
|
||||
runuser -u "$GITEA_USER" -- \
|
||||
gitea dump \
|
||||
--config "$GITEA_CONFIG" \
|
||||
--work-path "$GITEA_WORK_PATH" \
|
||||
--custom-path "$GITEA_CUSTOM_PATH" > /dev/null
|
||||
printf "gitea dump complete\n"
|
||||
popd > /dev/null || printf "could not chdir to %s\n" "$OLDPWD"
|
||||
elif [ "$1" == "post" ]; then
|
||||
printf "purging gitea backups\n"
|
||||
find "$GITEA_BACKUP_PATH" \
|
||||
-type f \
|
||||
-name '*.zip' \
|
||||
-mtime "+$GITEA_KEEP_DAYS" \
|
||||
-delete
|
||||
fi
|
||||
}
|
||||
|
||||
main "$@"
|
Loading…
Reference in New Issue
Block a user