Files
ubicacion-patasalada/app/middlewares/SecurityHeadersMiddleware.php

37 lines
1.2 KiB
PHP

<?php
declare(strict_types=1);
namespace app\middlewares;
use flight\Engine;
use Tracy\Debugger;
class SecurityHeadersMiddleware
{
protected Engine $app;
public function __construct(Engine $app)
{
$this->app = $app;
}
public function before(array $params): void
{
$nonce = $this->app->get('csp_nonce');
// development mode to execute Tracy debug bar CSS
$tracyCssBypass = "'nonce-{$nonce}'";
if(Debugger::$showBar === true) {
$tracyCssBypass = ' \'unsafe-inline\'';
}
$csp = "default-src 'self'; script-src 'self' 'nonce-{$nonce}' 'strict-dynamic'; style-src 'self' {$tracyCssBypass}; img-src 'self' data:;";
$this->app->response()->header('X-Frame-Options', 'SAMEORIGIN');
$this->app->response()->header("Content-Security-Policy", $csp);
$this->app->response()->header('X-XSS-Protection', '1; mode=block');
$this->app->response()->header('X-Content-Type-Options', 'nosniff');
$this->app->response()->header('Referrer-Policy', 'no-referrer-when-downgrade');
$this->app->response()->header('Strict-Transport-Security', 'max-age=31536000; includeSubDomains; preload');
$this->app->response()->header('Permissions-Policy', 'geolocation=()');
}
}