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.
16 * @package Zend_Validate
17 * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
18 * @license http://framework.zend.com/license/new-bsd New BSD License
23 * @see Zend_Validate_Abstract
25 require_once 'Zend/Validate/Abstract.php';
29 * @package Zend_Validate
30 * @copyright Copyright (c) 2005-2010 Zend Technologies USA Inc. (http://www.zend.com)
31 * @license http://framework.zend.com/license/new-bsd New BSD License
33 class Zend_Validate_Hex
extends Zend_Validate_Abstract
35 const INVALID
= 'hexInvalid';
36 const NOT_HEX
= 'notHex';
39 * Validation failure message template definitions
43 protected $_messageTemplates = array(
44 self
::INVALID
=> "Invalid type given, value should be a string",
45 self
::NOT_HEX
=> "'%value%' has not only hexadecimal digit characters",
49 * Defined by Zend_Validate_Interface
51 * Returns true if and only if $value contains only hexadecimal digit characters
53 * @param string $value
56 public function isValid($value)
58 if (!is_string($value) && !is_int($value)) {
59 $this->_error(self
::INVALID
);
63 $this->_setValue($value);
64 if (!ctype_xdigit((string) $value)) {
65 $this->_error(self
::NOT_HEX
);