aboutsummaryrefslogtreecommitdiffstats
path: root/mkosibuild-cron
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