improve log system

This commit is contained in:
2026-02-15 17:42:42 +00:00
parent 64b197cbe5
commit 456262ca65
5 changed files with 216 additions and 52 deletions
+29 -3
View File
@@ -8,13 +8,37 @@ LOG_FILE="/var/log/network_config.log"
UDEV_RULES_FILE="/etc/udev/rules.d/81-mac-spoof.rules"
IFACE="eth0"
WLAN_IFACE="wlan0"
MAX_LOG_SIZE_KB=1024 # 1MB
# --- Funções Auxiliares ---
# Função de Log
# Função de Log (modificada para usar logger)
log() {
local message="$1"
local timestamp=$(date '+%Y-%m-%d %H:%M:%S')
echo "$timestamp: $1" | tee -a "$LOG_FILE"
# Escreve no ficheiro de log
echo "$timestamp: $message" | tee -a "$LOG_FILE"
# Envia para o syslog (opcional)
logger -t "network_config" "$message"
}
# Função para limitar o tamanho do log
limit_log_size() {
local log_file="$1"
local max_size_kb="$2"
local max_size_bytes=$((max_size_kb * 1024))
if [ -f "$log_file" ]; then
local current_size=$(stat -c %s "$log_file" 2>/dev/null || wc -c < "$log_file" 2>/dev/null)
if [ "$current_size" -gt "$max_size_bytes" ]; then
log "Aviso: Ficheiro de log $log_file excedeu $max_size_kb KB. A truncar..."
tail -n 500 "$log_file" > "${log_file}.tmp" && mv "${log_file}.tmp" "$log_file"
log "Ficheiro de log truncado. As últimas 500 linhas foram mantidas."
fi
fi
}
# Função para verificar se a interface tem IP
@@ -273,8 +297,9 @@ monitor_network_task() {
if force_ip_renewal "$IFACE"; then
log "Monitor: Renovação de IP bem-sucedida. Wi-Fi permanece ativo até confirmação."
else
log "Monitor: Falha ao renovar IP. Ativando Wi-Fi como fallback..."
log "Monitor: Falha ao renovar IP."
if ip link show "$WLAN_IFACE" &> /dev/null && ip link show "$WLAN_IFACE" | grep -q "DOWN"; then
log "Ativando Wi-Fi como fallback..."
if ip link set "$WLAN_IFACE" up; then
log "Monitor: Wi-Fi ($WLAN_IFACE) ativado como fallback."
else
@@ -331,6 +356,7 @@ if [ "$(id -u)" -ne 0 ]; then
fi
mkdir -p "$(dirname "$LOG_FILE")"
limit_log_size "$LOG_FILE" "$MAX_LOG_SIZE_KB" # Verifica o tamanho do log no início
# 1. Verificar se a interface existe
if ! ip link show "$IFACE" &> /dev/null; then