# Gene-Niegles CMS - Configuration Apache

<IfModule mod_rewrite.c>
    RewriteEngine On
    RewriteBase /genealogie/test/

    # Proteger le dossier data (AVANT les autres règles)
    RewriteRule ^data/ - [F,L]

    # Exclure les dossiers d'assets du routing (laisser Apache les servir directement)
    RewriteRule ^assets/ - [L]
    RewriteRule ^uploads/ - [L]

    # Ne pas rediriger les fichiers et dossiers existants (CSS, JS, images, etc.)
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteCond %{REQUEST_FILENAME} !-d

    # Rediriger tout le reste vers router.php
    RewriteRule ^(.*)$ router.php [QSA,L]
</IfModule>

# Securite - Bloquer l'accès aux fichiers sensibles
<FilesMatch "\.(json|lock|md|log)$">
    Order Allow,Deny
    Deny from all
</FilesMatch>

# Empecher le listing des repertoires
Options -Indexes

# Cache pour les assets
<IfModule mod_expires.c>
    ExpiresActive On
    ExpiresByType image/jpg "access plus 1 month"
    ExpiresByType image/jpeg "access plus 1 month"
    ExpiresByType image/gif "access plus 1 month"
    ExpiresByType image/png "access plus 1 month"
    ExpiresByType image/webp "access plus 1 month"
    ExpiresByType text/css "access plus 1 week"
    ExpiresByType application/javascript "access plus 1 week"
</IfModule>

# Compression
<IfModule mod_deflate.c>
    AddOutputFilterByType DEFLATE text/html text/plain text/css application/json application/javascript text/xml application/xml
</IfModule>

# Securite headers
<IfModule mod_headers.c>
    Header always set X-Content-Type-Options "nosniff"
    Header always set X-Frame-Options "SAMEORIGIN"
    Header always set X-XSS-Protection "1; mode=block"
</IfModule>
