Validator.php 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. <?php
  2. /**
  3. * Zend Framework
  4. *
  5. * LICENSE
  6. *
  7. * This source file is subject to the new BSD license that is bundled
  8. * with this package in the file LICENSE.txt.
  9. * It is also available through the world-wide-web at this URL:
  10. * http://framework.zend.com/license/new-bsd
  11. * If you did not receive a copy of the license and are unable to
  12. * obtain it through the world-wide-web, please send an email
  13. * to license@zend.com so we can send you a copy immediately.
  14. *
  15. * @category Zend
  16. * @package Zend_Http
  17. * @subpackage UserAgent
  18. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. */
  21. require_once 'Zend/Http/UserAgent/Desktop.php';
  22. /**
  23. * Validator browser type matcher
  24. *
  25. * @category Zend
  26. * @package Zend_Http
  27. * @subpackage UserAgent
  28. * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
  29. * @license http://framework.zend.com/license/new-bsd New BSD License
  30. */
  31. class Zend_Http_UserAgent_Validator extends Zend_Http_UserAgent_Desktop
  32. {
  33. /**
  34. * User Agent Signatures
  35. *
  36. * @var array
  37. */
  38. protected static $_uaSignatures = array(
  39. 'htmlvalidator',
  40. 'csscheck',
  41. 'cynthia',
  42. 'htmlparser',
  43. 'validator',
  44. 'jfouffa',
  45. 'jigsaw',
  46. 'w3c_validator',
  47. 'wdg_validator',
  48. );
  49. /**
  50. * Comparison of the UserAgent chain and User Agent signatures
  51. *
  52. * @param string $userAgent User Agent chain
  53. * @param array $server $_SERVER like param
  54. * @return bool
  55. */
  56. public static function match($userAgent, $server)
  57. {
  58. return self::_matchAgentAgainstSignatures($userAgent, self::$_uaSignatures);
  59. }
  60. /**
  61. * Gives the current browser type
  62. *
  63. * @return string
  64. */
  65. public function getType()
  66. {
  67. return 'validator';
  68. }
  69. }