Configuracion Minima
This commit is contained in:
37
app/middlewares/SecurityHeadersMiddleware.php
Normal file
37
app/middlewares/SecurityHeadersMiddleware.php
Normal file
@@ -0,0 +1,37 @@
|
||||
<?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=()');
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user