<?php
/**
 * FavMasToKey - Configuration (version améliorée)
 */

// Empêcher l'accès direct au fichier
if (!defined('FAVMASTOKEY')) {
    die('Accès direct interdit');
}

// Environnement (development ou production)
define('ENVIRONMENT', 'development');

// Gestion des erreurs selon l'environnement
if (ENVIRONMENT === 'development') {
    error_reporting(E_ALL);
    ini_set('display_errors', 1);
    
    // Activer la journalisation pour le débogage
    ini_set('log_errors', 1);
    ini_set('error_log', __DIR__ . '/../debug.log');
} else {
    error_reporting(0);
    ini_set('display_errors', 0);
}

// Configuration de l'application
$config = [
    // Informations de l'application 
    'app_name' => 'FavMasToKey',
    'app_description' => 'Outil de transfert des favoris de Mastodon vers Misskey',
    'app_version' => '0.6.1', // Mise à jour de la version pour les améliorations
    
    // URL de base - Utilisée pour les liens dans l'application
    'app_url' => 'https://concepts.esenjin.xyz/favmastokey', // Remplacez par l'URL exacte de votre application
    
    // Paramètres Misskey API
    'misskey_api_endpoint' => '/api/notes/favorites/create',
    
    // Paramètres pour le traitement
    'batch_size' => 2,
    'timeout' => 90,
    'max_retries' => 3,
    'delay_between_requests' => 3000,     // Délai normal entre les requêtes (en millisecondes)
    
    // Paramètres pour le mode lent
    'slow_mode_delay' => 30000,           // Délai par défaut en mode lent (30 secondes)
    'slow_mode_min' => 10000,             // Délai minimum pour le mode lent (10 secondes)
    'slow_mode_max' => 300000,            // Délai maximum pour le mode lent (5 minutes)
    
    // Paramètres pour le mode tortue
    'tortoise_mode_delay' => 120000,      // Délai par défaut en mode tortue (2 minutes)
    'tortoise_mode_min' => 60000,         // Délai minimum pour le mode tortue (1 minute)
    'tortoise_mode_max' => 300000,        // Délai maximum pour le mode tortue (5 minutes)
    
    // AMÉLIORATION 1: Paramètres pour la file d'attente des rate-limit
    'rate_limit_queue_retry_delay' => 60000, // Délai avant de réessayer un élément en file d'attente (60 secondes)
    'rate_limit_max_retries' => 5,           // Nombre maximum de tentatives pour un même élément
    
    // AMÉLIORATION 2: Paramètres pour l'optimisation des favoris déjà existants
    'skip_delay_for_already_favorited' => true, // Ne pas attendre le délai pour les favoris déjà existants
    
    // AMÉLIORATION 3: Paramètres pour le cache de fédération
    'federation_cache_enabled' => true,   // Activer le cache de fédération
    'federation_cache_ttl' => 1440,       // Durée de vie du cache en minutes (24 heures)
    'federation_cache_cleanup_interval' => 60, // Intervalle de nettoyage du cache en minutes
    
    // AMÉLIORATION 4: Paramètres pour l'adaptation des délais
    'adaptive_delay_enabled' => true,     // Activer l'ajustement automatique des délais
    'adaptive_delay_step' => 5000,        // Pas d'augmentation du délai en cas de rate limiting (5 secondes)
    'adaptive_delay_max_increases' => 3,  // Nombre maximum d'augmentations automatiques du délai
    'adaptive_delay_decrease_rate' => 0.8, // Facteur de diminution du délai après succès (80%)
    
    // AMÉLIORATION 5: Paramètres pour les points de sauvegarde
    'checkpoint_interval' => 300000,      // Intervalle entre les points de sauvegarde (5 minutes)
    'checkpoint_max_stored' => 3,         // Nombre maximum de points de sauvegarde à conserver
    
    // Paramètres pour la pause automatique
    'auto_pause_enabled' => true,         // Activer la pause automatique en cas de trop de rate-limits
    'auto_pause_duration' => 15,          // Durée de pause automatique en minutes
    'auto_pause_threshold' => 3,          // Nombre d'erreurs de rate-limit consécutives avant pause
];

// Session
session_start();

/**
 * Affiche ou journalise des informations de débogage
 *
 * @param mixed $data Les données à déboguer
 * @param string $title Titre optionnel pour faciliter l'identification des logs
 * @param bool $log_to_file Journaliser dans un fichier plutôt que d'afficher
 */
function debug($data, $title = '', $log_to_file = false) {
    if (ENVIRONMENT === 'development') {
        $output = '';
        
        if (!empty($title)) {
            $output .= "=== {$title} ===\n";
        }
        
        if (is_array($data) || is_object($data)) {
            $output .= print_r($data, true);
        } else {
            $output .= $data;
        }
        
        if ($log_to_file) {
            error_log($output);
        } else {
            echo '<pre style="background:#111; color:#eee; padding:10px; border-radius:5px; overflow:auto; max-height:500px;">';
            echo htmlspecialchars($output);
            echo '</pre>';
        }
    }
}

/**
 * Journalise les performances des requêtes API pour analyse
 * 
 * @param string $domain Domaine de l'instance
 * @param string $action Type d'action (recherche, ajout favori, etc.)
 * @param int $response_time Temps de réponse en millisecondes
 * @param bool $success Succès de la requête
 * @param string $error_type Type d'erreur si échec
 */
function log_api_performance($domain, $action, $response_time, $success, $error_type = null) {
    if (ENVIRONMENT === 'development') {
        $status = $success ? 'success' : ($error_type === 'rate_limit' ? 'rate_limit' : 'error');
        $log_entry = date('Y-m-d H:i:s') . " | $domain | $action | {$response_time}ms | $status";
        
        if ($error_type) {
            $log_entry .= " | $error_type";
        }
        
        error_log("[API_PERF] " . $log_entry);
    }
}