#!/usr/bin/env php > /var/www/geosector/api/logs/cleanup_logs.log 2>&1 */ declare(strict_types=1); // Configuration define('LOG_RETENTION_DAYS', 10); define('LOCK_FILE', '/tmp/cleanup_logs.lock'); // Empêcher l'exécution multiple simultanée if (file_exists(LOCK_FILE)) { $lockTime = filemtime(LOCK_FILE); // Si le lock a plus de 30 minutes, on le supprime (processus probablement bloqué) if (time() - $lockTime > 1800) { unlink(LOCK_FILE); } else { die("Le processus est déjà en cours d'exécution\n"); } } // Créer le fichier de lock file_put_contents(LOCK_FILE, getmypid()); // Enregistrer un handler pour supprimer le lock en cas d'arrêt register_shutdown_function(function() { if (file_exists(LOCK_FILE)) { unlink(LOCK_FILE); } }); // Simuler l'environnement web pour AppConfig en CLI if (php_sapi_name() === 'cli') { // Détecter l'environnement basé sur le hostname $hostname = gethostname(); if (strpos($hostname, 'pra') !== false) { $_SERVER['SERVER_NAME'] = 'app3.geosector.fr'; } elseif (strpos($hostname, 'rca') !== false) { $_SERVER['SERVER_NAME'] = 'rapp.geosector.fr'; } else { $_SERVER['SERVER_NAME'] = 'dapp.geosector.fr'; // DVA par défaut } $_SERVER['HTTP_HOST'] = $_SERVER['HTTP_HOST'] ?? $_SERVER['SERVER_NAME']; $_SERVER['REMOTE_ADDR'] = $_SERVER['REMOTE_ADDR'] ?? '127.0.0.1'; // Définir getallheaders si elle n'existe pas (CLI) if (!function_exists('getallheaders')) { function getallheaders() { return []; } } } // Chargement de l'environnement require_once __DIR__ . '/../../vendor/autoload.php'; require_once __DIR__ . '/../../src/Config/AppConfig.php'; require_once __DIR__ . '/../../src/Services/LogService.php'; try { // Initialisation de la configuration $appConfig = AppConfig::getInstance(); $environment = $appConfig->getEnvironment(); // Définir le chemin du dossier logs $logDir = __DIR__ . '/../../logs'; if (!is_dir($logDir)) { echo "Le dossier de logs n'existe pas : {$logDir}\n"; exit(0); } // Date limite (10 jours en arrière) $cutoffDate = time() - (LOG_RETENTION_DAYS * 24 * 60 * 60); // Lister tous les fichiers .log (exclure le dossier events/) $logFiles = glob($logDir . '/*.log'); // Exclure explicitement les logs du sous-dossier events/ $logFiles = array_filter($logFiles, function($file) { return strpos($file, '/events/') === false; }); if (empty($logFiles)) { echo "Aucun fichier .log trouvé dans {$logDir}\n"; exit(0); } $deletedCount = 0; $deletedSize = 0; $deletedFiles = []; foreach ($logFiles as $file) { $fileTime = filemtime($file); // Vérifier si le fichier est plus vieux que la date limite if ($fileTime < $cutoffDate) { $fileSize = filesize($file); $fileName = basename($file); if (unlink($file)) { $deletedCount++; $deletedSize += $fileSize; $deletedFiles[] = $fileName; echo "Supprimé : {$fileName} (" . number_format($fileSize / 1024, 2) . " KB)\n"; } else { echo "ERREUR : Impossible de supprimer {$fileName}\n"; } } } // Logger le résumé if ($deletedCount > 0) { $message = sprintf( "Nettoyage des logs terminé - %d fichier(s) supprimé(s) - %.2f MB libérés", $deletedCount, $deletedSize / (1024 * 1024) ); LogService::log($message, [ 'level' => 'info', 'script' => 'cleanup_logs.php', 'environment' => $environment, 'deleted_count' => $deletedCount, 'deleted_size_mb' => round($deletedSize / (1024 * 1024), 2), 'deleted_files' => $deletedFiles ]); echo "\n" . $message . "\n"; } else { echo "Aucun fichier à supprimer (tous les logs ont moins de " . LOG_RETENTION_DAYS . " jours)\n"; } } catch (Exception $e) { $errorMsg = 'Erreur lors du nettoyage des logs : ' . $e->getMessage(); LogService::log($errorMsg, [ 'level' => 'error', 'script' => 'cleanup_logs.php', 'trace' => $e->getTraceAsString() ]); echo $errorMsg . "\n"; // Supprimer le lock en cas d'erreur if (file_exists(LOCK_FILE)) { unlink(LOCK_FILE); } exit(1); } // Supprimer le lock if (file_exists(LOCK_FILE)) { unlink(LOCK_FILE); } exit(0);