# ══════════════════════════════════════════════════════════ # TomTomGames Security Configuration # ══════════════════════════════════════════════════════════ Options -Indexes -Includes ServerSignature Off # ── Block all sensitive file types ─────────────────────── Order allow,deny Deny from all # ── Block direct access to sensitive PHP files ─────────── Order allow,deny Deny from all # ── Block access to includes and vendor folders ────────── RewriteEngine On RewriteRule ^includes/ - [F,L] RewriteRule ^vendor/ - [F,L] RewriteRule ^mail_queue/ - [F,L] RewriteRule ^\.git/ - [F,L] # ── Block common attack vectors ────────────────────────── RewriteEngine On # Block SQL injection attempts in query strings RewriteCond %{QUERY_STRING} (union|select|insert|drop|delete|update|cast|exec|declare|char|convert|truncate).*= [NC,OR] RewriteCond %{QUERY_STRING} (<|%3C).*script.*(>|%3E) [NC,OR] RewriteCond %{QUERY_STRING} \.\./\.\. [NC,OR] RewriteCond %{QUERY_STRING} (javascript|vbscript|expression|applet|meta|xml|blink|link|iframe|input|embed|script|object|marquee) [NC] RewriteRule .* - [F,L] # Block base64 encoded attacks RewriteCond %{QUERY_STRING} base64_encode.*\(.*\) [NC,OR] RewriteCond %{QUERY_STRING} base64_(en|de)code[^(]*\([^)]*\) [NC] RewriteRule .* - [F,L] # Block common exploit scanners and bad bots RewriteCond %{HTTP_USER_AGENT} (nikto|sqlmap|havij|nessus|masscan|zgrab|python-requests/2\.6|libwww-perl|wget|curl\/7\.[0-4]) [NC] RewriteRule .* - [F,L] # ── Block access to WordPress paths (scanners look for these) ── RewriteRule ^wp-admin - [F,L] RewriteRule ^wp-login - [F,L] RewriteRule ^xmlrpc - [F,L] RewriteRule ^\.env - [F,L] RewriteRule ^composer\. - [F,L] # ── Security Headers ────────────────────────────────────── # Prevent MIME type sniffing Header always set X-Content-Type-Options "nosniff" # Prevent clickjacking Header always set X-Frame-Options "DENY" # XSS protection Header always set X-XSS-Protection "1; mode=block" # Referrer policy Header always set Referrer-Policy "strict-origin-when-cross-origin" # Permissions policy — disable dangerous browser features Header always set Permissions-Policy "camera=(), microphone=(), geolocation=(), payment=(), usb=(), magnetometer=(), gyroscope=()" # Content Security Policy Header always set Content-Security-Policy "default-src 'self'; script-src 'self' 'unsafe-inline' 'unsafe-eval' https://web.squarecdn.com https://sandbox.web.squarecdn.com https://js.squareup.com; style-src 'self' 'unsafe-inline' https://fonts.googleapis.com; font-src 'self' data: https://fonts.gstatic.com; img-src 'self' data: blob: https:; connect-src 'self' https: wss:; frame-src 'none'; object-src 'none'" # Strict Transport Security — force HTTPS for 1 year Header always set Strict-Transport-Security "max-age=31536000; includeSubDomains" # Remove server info headers Header unset Server Header unset X-Powered-By # ── Canonical HTTPS + non-www redirect ─────────────────── RewriteEngine On RewriteCond %{HTTPS} off RewriteRule ^ https://%{HTTP_HOST}%{REQUEST_URI} [R=301,L] RewriteCond %{HTTP_HOST} ^www\.(.+)$ [NC] RewriteRule ^ https://%1%{REQUEST_URI} [R=301,L] # ── Block PHP execution in uploads folder (if it exists) ─ RewriteRule ^uploads/.*\.php$ - [F,L] # ── Gzip compression ────────────────────────────────────── AddOutputFilterByType DEFLATE text/html text/css text/javascript application/javascript application/json image/svg+xml # ── Browser caching ─────────────────────────────────────── ExpiresActive On ExpiresByType text/html "access plus 1 hour" ExpiresByType text/css "access plus 1 month" ExpiresByType application/javascript "access plus 1 month" ExpiresByType image/svg+xml "access plus 1 month" ExpiresByType image/png "access plus 1 month" ExpiresByType image/jpeg "access plus 1 month" ExpiresByType image/webp "access plus 1 month" ExpiresByType application/json "access plus 1 day"