blob: 41179e22ffac328c6056dadc4950beb35a3277fd (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
|
#!/usr/bin/env bash
#
# made by Dennis Eriksen <dnns.no> in 2020.
# Exit on error. Append "|| true" if you expect an error.
set -o errexit
# Exit on error inside any functions or subshells.
set -o errtrace
# Do not allow use of undefined vars. Use ${VAR:-} to use an undefined VAR
set -o nounset
# Catch the error in case mysqldump fails (but gzip succeeds) in `mysqldump |gzip`
set -o pipefail
LOGDIR=/var/log/mkosibuild/
BACKUPDIR=/var/lib/machines/.backup
BACKUPNUM=5
EXEC=mkosibuild # This provides the exec is in your $PATH
CRONSUFFIX="-cron" # Suffix for backups made through cron
export CRON=true
export CRONSUFFIX
MACHINES=()
# Import config to override above config
[[ -r /etc/mkosibuild ]] && . /etc/mkosibuild
# Check if logdir exists, and create it if not
[[ -d "${LOGDIR}" ]] || mkdir "${LOGDIR}"
chmod 750 "${LOGDIR}"
LOG="${LOGDIR}/mkosibuild.log"
touch "${LOG}" && chmod 640 "${LOG}"
for machine in ${MACHINES[*]}; do
BUILDLOG="${LOGDIR}/${machine}.buildlog.$(date +%Y%m%d%H%M%S)"
touch "${BUILDLOG}" && chmod 640 "${BUILDLOG}"
#exec >> "${LOG}"
echo "" >> "${LOG}"
echo "$(date '+%Y-%m-%d %H:%M:%S') - Building $machine" >> "${LOG}"
${EXEC} "$machine" &>> "${BUILDLOG}" && echo "$(date '+%Y-%m-%d %H:%M:%S') - Finished $machine" >> "${LOG}"
# Delete old backups
find "${BACKUPDIR}" -name "${machine}.*${CRONSUFFIX}" | tail -n +$((BACKUPNUM + 1)) | xargs rm -fv -- >> "${LOG}"
done
|