<IfModule mod_rewrite.c>
    <IfModule mod_negotiation.c>
        Options -MultiViews -Indexes
    </IfModule>

    RewriteEngine On

    # ===========================
    # SECURITY: PROTECT ENV FILES
    # ===========================
    <FilesMatch "^\.env">
        Order allow,deny
        Deny from all
    </FilesMatch>

    # Block other Laravel sensitive files
    <FilesMatch "^(composer\.json|composer\.lock|package\.json|yarn\.lock|artisan|\.git|\.svn|\.DS_Store)$">
        Order allow,deny
        Deny from all
    </FilesMatch>

    # Protect storage & vendor if placed inside public
    RedirectMatch 404 ^/(storage|vendor)/.*$

    # ===========================
    # Handle Authorization Header
    # ===========================
    RewriteCond %{HTTP:Authorization} .
    RewriteRule .* - [E=HTTP_AUTHORIZATION:%{HTTP:Authorization}]

    # =====================================
    # Redirect Trailing Slashes If Not A Folder
    # =====================================
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_URI} (.+)/$
    RewriteRule ^ %1 [L,R=301]

    # ===========================
    # Send Requests To Front Controller
    # ===========================
    RewriteCond %{REQUEST_FILENAME} !-d
    RewriteCond %{REQUEST_FILENAME} !-f
    RewriteRule ^ index.php [L]

</IfModule>

# ===========================
# SECURITY HEADERS
# ===========================
<IfModule mod_headers.c>
    Header set X-Frame-Options "SAMEORIGIN"
    Header set X-XSS-Protection "1; mode=block"
    Header set X-Content-Type-Options "nosniff"
    Header always set Referrer-Policy "no-referrer-when-downgrade"
    Header always set X-Download-Options "noopen"
    Header always set X-Permitted-Cross-Domain-Policies "none"
</IfModule>
