2
0

Priority.php 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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_Validate
  17. * @subpackage Sitemap
  18. * @copyright Copyright (c) 2005-2008 Zend Technologies USA Inc. (http://www.zend.com)
  19. * @license http://framework.zend.com/license/new-bsd New BSD License
  20. */
  21. /**
  22. * @see Zend_Validate_Abstract
  23. */
  24. require_once 'Zend/Validate/Abstract.php';
  25. /**
  26. * Validates whether a given value is valid as a sitemap <priority> value
  27. *
  28. * @link http://www.sitemaps.org/protocol.php Sitemaps XML format
  29. *
  30. * @category Zend
  31. * @package Zend_Validate
  32. * @subpackage Sitemap
  33. * @copyright Copyright (c) 2005-2008 Zend Technologies USA Inc. (http://www.zend.com)
  34. * @license http://framework.zend.com/license/new-bsd New BSD License
  35. */
  36. class Zend_Validate_Sitemap_Priority extends Zend_Validate_Abstract
  37. {
  38. /**
  39. * Validation key for not valid
  40. *
  41. */
  42. const NOT_VALID = 'invalidSitemapPriority';
  43. /**
  44. * Validation failure message template definitions
  45. *
  46. * @var array
  47. */
  48. protected $_messageTemplates = array(
  49. self::NOT_VALID => "'%value%' is not a valid sitemap priority",
  50. );
  51. /**
  52. * Validates if a string is valid as a sitemap priority
  53. *
  54. * @link http://www.sitemaps.org/protocol.php#prioritydef <priority>
  55. *
  56. * @param string $value value to validate
  57. * @return boolean
  58. */
  59. public function isValid($value)
  60. {
  61. $this->_setValue($value);
  62. if (!is_numeric($value)) {
  63. return false;
  64. }
  65. $value = (float)$value;
  66. return $value >= 0 && $value <= 1;
  67. }
  68. }