 blitz-php    /
                    framework
                      blitz-php    /
                    framework
                
                            | 1 | <?php | ||
| 2 | |||
| 3 | /** | ||
| 4 | * This file is part of Blitz PHP framework. | ||
| 5 | * | ||
| 6 | * (c) 2022 Dimitri Sitchet Tomkeu <[email protected]> | ||
| 7 | * | ||
| 8 | * For the full copyright and license information, please view | ||
| 9 | * the LICENSE file that was distributed with this source code. | ||
| 10 | */ | ||
| 11 | |||
| 12 | namespace BlitzPHP\Middlewares; | ||
| 13 | |||
| 14 | use Psr\Http\Message\ResponseInterface; | ||
| 15 | use Psr\Http\Message\ServerRequestInterface; | ||
| 16 | use Psr\Http\Server\MiddlewareInterface; | ||
| 17 | use Psr\Http\Server\RequestHandlerInterface; | ||
| 18 | |||
| 19 | /** | ||
| 20 | * Ajoute les entete de securites communs | ||
| 21 | */ | ||
| 22 | class SecureHeaders implements MiddlewareInterface | ||
| 23 | { | ||
| 24 | /** | ||
| 25 | * @var array<string, string> | ||
| 26 | */ | ||
| 27 | protected array $headers = [ | ||
| 28 | // https://owasp.org/www-project-secure-headers/#x-frame-options | ||
| 29 | 'X-Frame-Options' => 'SAMEORIGIN', | ||
| 30 | |||
| 31 | // https://owasp.org/www-project-secure-headers/#x-content-type-options | ||
| 32 | 'X-Content-Type-Options' => 'nosniff', | ||
| 33 | |||
| 34 | // https://docs.microsoft.com/en-us/previous-versions/windows/internet-explorer/ie-developer/compatibility/jj542450(v=vs.85)#the-noopen-directive | ||
| 35 | 'X-Download-Options' => 'noopen', | ||
| 36 | |||
| 37 | // https://owasp.org/www-project-secure-headers/#x-permitted-cross-domain-policies | ||
| 38 | 'X-Permitted-Cross-Domain-Policies' => 'none', | ||
| 39 | |||
| 40 | // https://owasp.org/www-project-secure-headers/#referrer-policy | ||
| 41 | 'Referrer-Policy' => 'same-origin', | ||
| 42 | |||
| 43 | // https://owasp.org/www-project-secure-headers/#x-xss-protection | ||
| 44 | // Si vous n'avez pas besoin de prendre en charge les navigateurs existants, il est recommandé d'utiliser | ||
| 45 | // Content-Security-Policy sans autoriser les scripts en ligne non sécurisés à la place. | ||
| 46 | // 'X-XSS-Protection' => '1; mode=block', | ||
| 47 | ]; | ||
| 48 | |||
| 49 | public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface | ||
| 50 |     { | ||
| 51 | $response = $handler->handle($request); | ||
| 52 | |||
| 53 |         foreach ($this->headers as $header => $value) { | ||
| 54 | $response = $response->withHeader($header, $value); | ||
| 55 | } | ||
| 56 | |||
| 57 | return $response; | ||
| 0 ignored issues–
                            show             Bug
            Best Practice
    
    
    
        introduced 
                            by  
  Loading history... | |||
| 58 | } | ||
| 59 | } | ||
| 60 | 
