Blame | Last modification | View Log | RSS feed
<?php/* vim: set expandtab tabstop=4 shiftwidth=4: *///// +----------------------------------------------------------------------+// | PHP Version 4 |// +----------------------------------------------------------------------+// | Copyright (c) 1997-2002 The PHP Group |// +----------------------------------------------------------------------+// | This source file is subject to version 2.02 of the PHP license, |// | that is bundled with this package in the file LICENSE, and is |// | available at through the world-wide-web at |// | http://www.php.net/license/3_0.txt. |// | If you did not receive a copy of the PHP license and are unable to |// | obtain it through the world-wide-web, please send a note to |// | license@php.net so we can mail you a copy immediately. |// +----------------------------------------------------------------------+// | Authors: Harry Fuecks <hfuecks@phppatterns.com> |// +----------------------------------------------------------------------+//// $Id: Validator.php,v 1.1 2005-09-30 14:58:00 ddelon Exp $///*** @package Calendar* @version $Id: Validator.php,v 1.1 2005-09-30 14:58:00 ddelon Exp $*//*** Validation Error Messages*/if (!defined('CALENDAR_VALUE_TOOSMALL')) {define('CALENDAR_VALUE_TOOSMALL', 'Too small: min = ');}if (!defined('CALENDAR_VALUE_TOOLARGE')) {define('CALENDAR_VALUE_TOOLARGE', 'Too large: max = ');}/*** Used to validate any given Calendar date object. Instances of this class* can be obtained from any data object using the getValidator method* @see Calendar::getValidator()* @package Calendar* @access public*/class Calendar_Validator{/*** Instance of the Calendar date object to validate* @var object* @access private*/var $calendar;/*** Instance of the Calendar_Engine* @var object* @access private*/var $cE;/*** Array of errors for validation failures* @var array* @access private*/var $errors = array();/*** Constructs Calendar_Validator* @param object subclass of Calendar* @access public*/function Calendar_Validator(& $calendar){$this->calendar = & $calendar;$this->cE = & $calendar->getEngine();}/*** Calls all the other isValidXXX() methods in the validator* @return boolean* @access public*/function isValid(){$checks = array('isValidYear', 'isValidMonth', 'isValidDay','isValidHour', 'isValidMinute', 'isValidSecond');$valid = true;foreach ($checks as $check) {if (!$this->{$check}()) {$valid = false;}}return $valid;}/*** Check whether this is a valid year* @return boolean* @access public*/function isValidYear(){$y = $this->calendar->thisYear();$min = $this->cE->getMinYears();if ($min > $y) {$this->errors[] = new Calendar_Validation_Error('Year', $y, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = $this->cE->getMaxYears();if ($y > $max) {$this->errors[] = new Calendar_Validation_Error('Year', $y, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Check whether this is a valid month* @return boolean* @access public*/function isValidMonth(){$m = $this->calendar->thisMonth();$min = 1;if ($min > $m) {$this->errors[] = new Calendar_Validation_Error('Month', $m, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = $this->cE->getMonthsInYear($this->calendar->thisYear());if ($m > $max) {$this->errors[] = new Calendar_Validation_Error('Month', $m, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Check whether this is a valid day* @return boolean* @access public*/function isValidDay(){$d = $this->calendar->thisDay();$min = 1;if ($min > $d) {$this->errors[] = new Calendar_Validation_Error('Day', $d, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = $this->cE->getDaysInMonth($this->calendar->thisYear(), $this->calendar->thisMonth());if ($d > $max) {$this->errors[] = new Calendar_Validation_Error('Day', $d, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Check whether this is a valid hour* @return boolean* @access public*/function isValidHour(){$h = $this->calendar->thisHour();$min = 0;if ($min > $h) {$this->errors[] = new Calendar_Validation_Error('Hour', $h, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = ($this->cE->getHoursInDay($this->calendar->thisDay())-1);if ($h > $max) {$this->errors[] = new Calendar_Validation_Error('Hour', $h, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Check whether this is a valid minute* @return boolean* @access public*/function isValidMinute(){$i = $this->calendar->thisMinute();$min = 0;if ($min > $i) {$this->errors[] = new Calendar_Validation_Error('Minute', $i, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = ($this->cE->getMinutesInHour($this->calendar->thisHour())-1);if ($i > $max) {$this->errors[] = new Calendar_Validation_Error('Minute', $i, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Check whether this is a valid second* @return boolean* @access public*/function isValidSecond(){$s = $this->calendar->thisSecond();$min = 0;if ($min > $s) {$this->errors[] = new Calendar_Validation_Error('Second', $s, CALENDAR_VALUE_TOOSMALL.$min);return false;}$max = ($this->cE->getSecondsInMinute($this->calendar->thisMinute())-1);if ($s > $max) {$this->errors[] = new Calendar_Validation_Error('Second', $s, CALENDAR_VALUE_TOOLARGE.$max);return false;}return true;}/*** Iterates over any validation errors* @return mixed either Calendar_Validation_Error or false* @access public*/function fetch(){$error = each ($this->errors);if ($error) {return $error['value'];} else {reset($this->errors);return false;}}}/*** For Validation Error messages* @see Calendar::fetch()* @package Calendar* @access public*/class Calendar_Validation_Error{/*** Date unit (e.g. month,hour,second) which failed test* @var string* @access private*/var $unit;/*** Value of unit which failed test* @var int* @access private*/var $value;/*** Validation error message* @var string* @access private*/var $message;/*** Constructs Calendar_Validation_Error* @param string Date unit (e.g. month,hour,second)* @param int Value of unit which failed test* @param string Validation error message* @access protected*/function Calendar_Validation_Error($unit,$value,$message){$this->unit = $unit;$this->value = $value;$this->message = $message;}/*** Returns the Date unit* @return string* @access public*/function getUnit(){return $this->unit;}/*** Returns the value of the unit* @return int* @access public*/function getValue(){return $this->value;}/*** Returns the validation error message* @return string* @access public*/function getMessage(){return $this->message;}/*** Returns a string containing the unit, value and error message* @return string* @access public*/function toString (){return $this->unit.' = '.$this->value.' ['.$this->message.']';}}?>