00001 <?php 00002 /** 00003 * Magento 00004 * 00005 * NOTICE OF LICENSE 00006 * 00007 * This source file is subject to the Open Software License (OSL 3.0) 00008 * that is bundled with this package in the file LICENSE.txt. 00009 * It is also available through the world-wide-web at this URL: 00010 * http://opensource.org/licenses/osl-3.0.php 00011 * If you did not receive a copy of the license and are unable to 00012 * obtain it through the world-wide-web, please send an email 00013 * to license@magentocommerce.com so we can send you a copy immediately. 00014 * 00015 * DISCLAIMER 00016 * 00017 * Do not edit or add to this file if you wish to upgrade Magento to newer 00018 * versions in the future. If you wish to customize Magento for your 00019 * needs please refer to http://www.magentocommerce.com for more information. 00020 * 00021 * @category Mage 00022 * @package Mage_Customer 00023 * @copyright Copyright (c) 2008 Irubin Consulting Inc. DBA Varien (http://www.varien.com) 00024 * @license http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0) 00025 */ 00026 00027 /** 00028 * Customer password attribute backend 00029 * 00030 * @category Mage 00031 * @package Mage_Customer 00032 * @author Magento Core Team <core@magentocommerce.com> 00033 */ 00034 class Mage_Customer_Model_Customer_Attribute_Backend_Password extends Mage_Eav_Model_Entity_Attribute_Backend_Abstract 00035 { 00036 public function beforeSave($object) 00037 { 00038 $password = trim($object->getPassword()); 00039 if ($password) { 00040 if(Mage::helper('core/string')->strlen($password)<6){ 00041 Mage::throwException(Mage::helper('customer')->__('Password must have at least 6 characters. Leading or trailing spaces will be ignored.')); 00042 } 00043 $object->setPasswordHash($object->hashPassword($password)); 00044 } 00045 } 00046 00047 public function validate($object) 00048 { 00049 if ($password = $object->getPassword()) { 00050 if ($password == $object->getPasswordConfirm()) { 00051 return true; 00052 } 00053 } 00054 00055 return parent::validate($object); 00056 } 00057 00058 }