mirror of
https://github.com/myronblair/novacpx
synced 2026-06-30 17:50:41 -05:00
Fix OS upgrade script: date format and backup dir permission
- date -u +%H:%M:%S UTC → ts() helper with date -u +"%H:%M:%S UTC" (UTC as a separate word was being treated as an extra date argument) - Backup dir changed from /var/novacpx/backups/ (root-owned, doesn't exist) to /tmp/novacpx-backup-TIMESTAMP/ (always writable by www-data) Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -144,32 +144,33 @@ match ($action) {
|
|||||||
$script = "/tmp/ncpx-os-update-{$jobId}.sh";
|
$script = "/tmp/ncpx-os-update-{$jobId}.sh";
|
||||||
$webSvc = defined('WEB_SERVER') && WEB_SERVER === 'nginx' ? 'nginx' : 'apache2';
|
$webSvc = defined('WEB_SERVER') && WEB_SERVER === 'nginx' ? 'nginx' : 'apache2';
|
||||||
$webRoot = defined('WEB_ROOT') ? WEB_ROOT : '/srv/novacpx/public';
|
$webRoot = defined('WEB_ROOT') ? WEB_ROOT : '/srv/novacpx/public';
|
||||||
$backupDir = '/var/novacpx/backups/pre-os-update-' . date('YmdHis');
|
$backupDir = '/tmp/novacpx-backup-' . date('YmdHis');
|
||||||
|
|
||||||
$sh = <<<BASH
|
$sh = <<<BASH
|
||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
exec > {$logFile} 2>&1
|
exec > {$logFile} 2>&1
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Preparing backup..."
|
ts() { date -u +"%H:%M:%S UTC"; }
|
||||||
|
echo "[\$(ts)] Preparing backup..."
|
||||||
mkdir -p {$backupDir}
|
mkdir -p {$backupDir}
|
||||||
cp -a {$webRoot} {$backupDir}/public 2>/dev/null
|
cp -a {$webRoot} {$backupDir}/public 2>/dev/null
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Updating package lists..."
|
echo "[\$(ts)] Updating package lists..."
|
||||||
sudo apt-get update -q
|
sudo apt-get update -q
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Running upgrade (non-interactive)..."
|
echo "[\$(ts)] Running upgrade (non-interactive)..."
|
||||||
DEBIAN_FRONTEND=noninteractive sudo apt-get upgrade -y \\
|
DEBIAN_FRONTEND=noninteractive sudo apt-get upgrade -y \
|
||||||
-o Dpkg::Options::="--force-confdef" \\
|
-o Dpkg::Options::="--force-confdef" \
|
||||||
-o Dpkg::Options::="--force-confold"
|
-o Dpkg::Options::="--force-confold"
|
||||||
UPGRADE_EXIT=\$?
|
UPGRADE_EXIT=\$?
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Checking services..."
|
echo "[\$(ts)] Checking services..."
|
||||||
for SVC in {$webSvc} mysql postfix dovecot; do
|
for SVC in {$webSvc} mysql postfix dovecot; do
|
||||||
if systemctl is-active --quiet \$SVC 2>/dev/null; then :; else
|
if systemctl is-active --quiet \$SVC 2>/dev/null; then :; else
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Restarting \$SVC..."
|
echo "[\$(ts)] Restarting \$SVC..."
|
||||||
sudo systemctl restart \$SVC 2>/dev/null && echo " \$SVC restarted OK" || echo " \$SVC restart FAILED"
|
sudo systemctl restart \$SVC 2>/dev/null && echo " \$SVC restarted OK" || echo " \$SVC restart FAILED"
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
if [ \$UPGRADE_EXIT -eq 0 ]; then
|
if [ \$UPGRADE_EXIT -eq 0 ]; then
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Upgrade complete."
|
echo "[\$(ts)] Upgrade complete."
|
||||||
else
|
else
|
||||||
echo "[$(date -u +%H:%M:%S UTC)] Upgrade finished with errors (exit code \$UPGRADE_EXIT)."
|
echo "[\$(ts)] Upgrade finished with errors (exit code \$UPGRADE_EXIT)."
|
||||||
fi
|
fi
|
||||||
echo \$UPGRADE_EXIT > {$doneFile}
|
echo \$UPGRADE_EXIT > {$doneFile}
|
||||||
BASH;
|
BASH;
|
||||||
|
|||||||
Reference in New Issue
Block a user