TYPO3 API  SVNRelease
EmailAddressValidator.php
Go to the documentation of this file.
00001 <?php
00002 /***************************************************************
00003 *  Copyright notice
00004 *
00005 *  (c) 2009 Jochen Rau <jochen.rau@typoplanet.de>
00006 *  All rights reserved
00007 *
00008 *  This class is a backport of the corresponding class of FLOW3.
00009 *  All credits go to the v5 team.
00010 *
00011 *  This script is part of the TYPO3 project. The TYPO3 project is
00012 *  free software; you can redistribute it and/or modify
00013 *  it under the terms of the GNU General Public License as published by
00014 *  the Free Software Foundation; either version 2 of the License, or
00015 *  (at your option) any later version.
00016 *
00017 *  The GNU General Public License can be found at
00018 *  http://www.gnu.org/copyleft/gpl.html.
00019 *
00020 *  This script is distributed in the hope that it will be useful,
00021 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
00022 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00023 *  GNU General Public License for more details.
00024 *
00025 *  This copyright notice MUST APPEAR in all copies of the script!
00026 ***************************************************************/
00027 
00028 /**
00029  * Validator for email addresses
00030  *
00031  * @package Extbase
00032  * @subpackage Validation\Validator
00033  * @version $Id: EmailAddressValidator.php 1792 2010-01-19 00:06:05Z jocrau $
00034  */
00035 class Tx_Extbase_Validation_Validator_EmailAddressValidator extends Tx_Extbase_Validation_Validator_AbstractValidator {
00036 
00037     /**
00038      * Checks if the given value is a valid email address.
00039      * If at least one error occurred, the result is FALSE.
00040      *
00041      * The regexp is a modified version of the last one shown on
00042      * http://www.regular-expressions.info/email.html
00043      *
00044      * @param mixed $value The value that should be validated
00045      * @return boolean TRUE if the value is valid, FALSE if an error occured
00046      */
00047     public function isValid($value) {
00048         $this->errors = array();
00049         if(is_string($value) && preg_match('
00050                 /
00051                     ^[a-z0-9!#$%&\'*+\/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&\'*+\/=?^_`{|}~-]+)*
00052                     @
00053                     (?:
00054                         (?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+(?:[a-z]{2}|aero|asia|biz|cat|com|edu|coop|gov|info|int|invalid|jobs|localdomain|mil|mobi|museum|name|net|org|pro|tel|travel)|
00055                         localhost|
00056                         (?:(?:\d{1,2}|1\d{1,2}|2[0-5][0-5])\.){3}(?:(?:\d{1,2}|1\d{1,2}|2[0-5][0-5]))
00057                     )
00058                     \b
00059                 /ix', $value)) return TRUE;
00060         $this->addError('The given subject was not a valid email address.', 1221559976);
00061         return FALSE;
00062     }
00063 }
00064 
00065 ?>