2026-04-21 09:53:23 +00:00
|
|
|
#!/bin/sh
|
2026-04-24 08:30:20 +00:00
|
|
|
# Runs backup_db.sh at each time in BACKUP_TIMES (comma-separated HH:MM list).
|
|
|
|
|
# Times are interpreted in the container's local TZ (set via TZ env; default
|
|
|
|
|
# Africa/Nairobi in the Dockerfile). Defaults: 02:30, 08:30, 14:30, 20:30 local.
|
2026-04-24 08:00:02 +00:00
|
|
|
#
|
2026-04-24 08:30:20 +00:00
|
|
|
# Back-compat: legacy BACKUP_TIMES_UTC or BACKUP_HOUR/BACKUP_MINUTE are still honored.
|
2026-04-21 09:53:23 +00:00
|
|
|
|
|
|
|
|
set -eu
|
|
|
|
|
|
2026-04-24 08:30:20 +00:00
|
|
|
if [ -n "${BACKUP_TIMES:-}" ]; then
|
|
|
|
|
TIMES="$BACKUP_TIMES"
|
|
|
|
|
elif [ -n "${BACKUP_TIMES_UTC:-}" ]; then
|
2026-04-24 08:00:02 +00:00
|
|
|
TIMES="$BACKUP_TIMES_UTC"
|
|
|
|
|
elif [ -n "${BACKUP_HOUR:-}" ] || [ -n "${BACKUP_MINUTE:-}" ]; then
|
|
|
|
|
TIMES="$(printf '%02d:%02d' "${BACKUP_HOUR:-2}" "${BACKUP_MINUTE:-30}")"
|
|
|
|
|
else
|
|
|
|
|
TIMES="02:30,08:30,14:30,20:30"
|
|
|
|
|
fi
|
|
|
|
|
|
2026-04-24 08:30:20 +00:00
|
|
|
TS_FMT='+%FT%T%z'
|
|
|
|
|
echo "[$(date "$TS_FMT")] TZ=${TZ:-UTC} backup schedule: ${TIMES}"
|
2026-04-21 09:53:23 +00:00
|
|
|
|
|
|
|
|
if [ "${BACKUP_RUN_ON_START:-0}" = "1" ]; then
|
2026-04-24 08:30:20 +00:00
|
|
|
echo "[$(date "$TS_FMT")] BACKUP_RUN_ON_START=1 — running backup immediately"
|
|
|
|
|
/app/backup_db.sh || echo "[$(date "$TS_FMT")] initial backup failed (continuing)"
|
2026-04-21 09:53:23 +00:00
|
|
|
fi
|
|
|
|
|
|
2026-04-24 08:30:20 +00:00
|
|
|
# Compute epoch for "today HH:MM local" on both GNU and BSD date.
|
2026-04-24 08:00:02 +00:00
|
|
|
slot_to_epoch_today() {
|
|
|
|
|
HM="$1"
|
2026-04-24 08:30:20 +00:00
|
|
|
date -d "today ${HM}:00" +%s 2>/dev/null \
|
|
|
|
|
|| date -j -f "%H:%M:%S" "${HM}:00" +%s
|
2026-04-24 08:00:02 +00:00
|
|
|
}
|
|
|
|
|
|
2026-04-21 09:53:23 +00:00
|
|
|
while true; do
|
2026-04-24 08:30:20 +00:00
|
|
|
NOW_EPOCH=$(date +%s)
|
2026-04-24 08:00:02 +00:00
|
|
|
NEXT=""
|
|
|
|
|
# Find the smallest TARGET > NOW across all configured slots (rolling to tomorrow if needed).
|
|
|
|
|
OLDIFS="$IFS"
|
|
|
|
|
IFS=','
|
|
|
|
|
for HM in $TIMES; do
|
|
|
|
|
HM="$(echo "$HM" | tr -d ' ')"
|
|
|
|
|
[ -z "$HM" ] && continue
|
|
|
|
|
T=$(slot_to_epoch_today "$HM")
|
|
|
|
|
if [ "$T" -le "$NOW_EPOCH" ]; then
|
|
|
|
|
T=$((T + 86400))
|
|
|
|
|
fi
|
|
|
|
|
if [ -z "$NEXT" ] || [ "$T" -lt "$NEXT" ]; then
|
|
|
|
|
NEXT="$T"
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
IFS="$OLDIFS"
|
|
|
|
|
|
|
|
|
|
if [ -z "$NEXT" ]; then
|
2026-04-24 08:30:20 +00:00
|
|
|
echo "[$(date "$TS_FMT")] no valid times in BACKUP_TIMES='${TIMES}'; sleeping 1h"
|
2026-04-24 08:00:02 +00:00
|
|
|
sleep 3600
|
|
|
|
|
continue
|
2026-04-21 09:53:23 +00:00
|
|
|
fi
|
2026-04-24 08:00:02 +00:00
|
|
|
|
|
|
|
|
SLEEP=$((NEXT - NOW_EPOCH))
|
2026-04-24 08:30:20 +00:00
|
|
|
NEXT_ISO=$(date -d "@${NEXT}" "$TS_FMT" 2>/dev/null || date -r "${NEXT}" "$TS_FMT")
|
|
|
|
|
echo "[$(date "$TS_FMT")] next backup in ${SLEEP}s (at ${NEXT_ISO})"
|
2026-04-21 09:53:23 +00:00
|
|
|
sleep "$SLEEP"
|
2026-04-24 08:30:20 +00:00
|
|
|
/app/backup_db.sh || echo "[$(date "$TS_FMT")] backup failed (will retry at next slot)"
|
2026-04-21 09:53:23 +00:00
|
|
|
done
|