XssProtection.php 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Framework\App\Response\HeaderProvider;
  7. use Magento\Framework\App\Response\HeaderProvider\HeaderProviderInterface;
  8. use Magento\Framework\HTTP\Header;
  9. class XssProtection extends AbstractHeaderProvider
  10. {
  11. /**
  12. * @var string
  13. */
  14. protected $headerName = 'X-XSS-Protection';
  15. /** Matches IE 8 browsers */
  16. const IE_8_USER_AGENT = 'MSIE 8';
  17. /** Value for browsers except IE 8 */
  18. const HEADER_ENABLED = '1; mode=block';
  19. /** Value for IE 8 */
  20. const HEADER_DISABLED = '0';
  21. /**
  22. * @var \Magento\Framework\HTTP\Header
  23. */
  24. private $headerService;
  25. /**
  26. * @param Header $headerService
  27. */
  28. public function __construct(Header $headerService)
  29. {
  30. $this->headerService = $headerService;
  31. }
  32. /**
  33. * Header value. Must be disabled for IE 8.
  34. *
  35. * @return string
  36. */
  37. public function getValue()
  38. {
  39. return strpos($this->headerService->getHttpUserAgent(), self::IE_8_USER_AGENT) === false
  40. ? self::HEADER_ENABLED
  41. : self::HEADER_DISABLED;
  42. }
  43. }