This repository has been archived on 2024-12-01. You can view files and clone it, but cannot push or open issues or pull requests.
factuges_web/www/protected/modules/yii-user-master/UserModule.php
david e93adbdd4e - Importación inicial
- Registro, activación y entrada de usuarios


git-svn-id: https://192.168.0.254/svn/Rodax.factuges_web/trunk@2 e455b18d-f7fe-5245-9c43-e2c35af70a32
2013-06-13 16:04:48 +00:00

275 lines
6.5 KiB
PHP

<?php
/**
* Yii-User module
*
* @author Mikhail Mangushev <mishamx@gmail.com>
* @link http://yii-user.2mx.org/
* @license http://www.opensource.org/licenses/bsd-license.php
* @version $Id: UserModule.php 132 2011-10-30 10:45:01Z mishamx $
*/
class UserModule extends CWebModule
{
/**
* @var int
* @desc items on page
*/
public $user_page_size = 10;
/**
* @var int
* @desc items on page
*/
public $fields_page_size = 10;
/**
* @var string
* @desc hash method (md5,sha1 or algo hash function http://www.php.net/manual/en/function.hash.php)
*/
public $hash='md5';
/**
* @var boolean
* @desc use email for activation user account
*/
public $sendActivationMail=true;
/**
* @var boolean
* @desc allow auth for is not active user
*/
public $loginNotActiv=false;
/**
* @var boolean
* @desc activate user on registration (only $sendActivationMail = false)
*/
public $activeAfterRegister=false;
/**
* @var boolean
* @desc login after registration (need loginNotActiv or activeAfterRegister = true)
*/
public $autoLogin=true;
public $registrationUrl = array("/user/registration");
public $recoveryUrl = array("/user/recovery/recovery");
public $loginUrl = array("/user/login");
public $logoutUrl = array("/user/logout");
public $profileUrl = array("/user/profile");
public $returnUrl = array("/user/profile");
public $returnLogoutUrl = array("/user/login");
/**
* @var int
* @desc Remember Me Time (seconds), defalt = 2592000 (30 days)
*/
public $rememberMeTime = 2592000; // 30 days
public $fieldsMessage = '';
/**
* @var array
* @desc User model relation from other models
* @see http://www.yiiframework.com/doc/guide/database.arr
*/
public $relations = array();
/**
* @var array
* @desc Profile model relation from other models
*/
public $profileRelations = array();
/**
* @var boolean
*/
public $captcha = array('registration'=>true);
/**
* @var boolean
*/
//public $cacheEnable = false;
public $tableUsers = '{{users}}';
public $tableProfiles = '{{profiles}}';
public $tableProfileFields = '{{profiles_fields}}';
public $defaultScope = array(
'with'=>array('profile'),
);
static private $_user;
static private $_users=array();
static private $_userByName=array();
static private $_admin;
static private $_admins;
/**
* @var array
* @desc Behaviors for models
*/
public $componentBehaviors=array();
public function init()
{
// this method is called when the module is being created
// you may place code here to customize the module or the application
// import the module-level models and components
$this->setImport(array(
'user.models.*',
'user.components.*',
));
}
public function getBehaviorsFor($componentName){
if (isset($this->componentBehaviors[$componentName])) {
return $this->componentBehaviors[$componentName];
} else {
return array();
}
}
public function beforeControllerAction($controller, $action)
{
if(parent::beforeControllerAction($controller, $action))
{
// this method is called before any module controller action is performed
// you may place customized code here
return true;
}
else
return false;
}
/**
* @param $str
* @param $params
* @param $dic
* @return string
*/
public static function t($str='',$params=array(),$dic='user') {
if (Yii::t("UserModule", $str)==$str)
return Yii::t("UserModule.".$dic, $str, $params);
else
return Yii::t("UserModule", $str, $params);
}
/**
* @return hash string.
*/
public static function encrypting($string="") {
$hash = Yii::app()->getModule('user')->hash;
if ($hash=="md5")
return md5($string);
if ($hash=="sha1")
return sha1($string);
else
return hash($hash,$string);
}
/**
* @param $place
* @return boolean
*/
public static function doCaptcha($place = '') {
if(!extension_loaded('gd'))
return false;
if (in_array($place, Yii::app()->getModule('user')->captcha))
return Yii::app()->getModule('user')->captcha[$place];
return false;
}
/**
* Return admin status.
* @return boolean
*/
public static function isAdmin() {
if(Yii::app()->user->isGuest)
return false;
else {
if (!isset(self::$_admin)) {
if(self::user()->superuser)
self::$_admin = true;
else
self::$_admin = false;
}
return self::$_admin;
}
}
/**
* Return admins.
* @return array syperusers names
*/
public static function getAdmins() {
if (!self::$_admins) {
$admins = User::model()->active()->superuser()->findAll();
$return_name = array();
foreach ($admins as $admin)
array_push($return_name,$admin->username);
self::$_admins = ($return_name)?$return_name:array('');
}
return self::$_admins;
}
/**
* Send to user mail
*/
public static function sendMail($email,$subject,$message) {
$adminEmail = Yii::app()->params['adminEmail'];
$headers = "MIME-Version: 1.0\r\nFrom: $adminEmail\r\nReply-To: $adminEmail\r\nContent-Type: text/html; charset=utf-8";
$message = wordwrap($message, 70);
$message = str_replace("\n.", "\n..", $message);
return mail($email,'=?UTF-8?B?'.base64_encode($subject).'?=',$message,$headers);
}
/**
* Send to user mail
*/
public function sendMailToUser($user_id,$subject,$message,$from='') {
$user = User::model()->findbyPk($user_id);
if (!$from) $from = Yii::app()->params['adminEmail'];
$headers="From: ".$from."\r\nReply-To: ".Yii::app()->params['adminEmail'];
return mail($user->email,'=?UTF-8?B?'.base64_encode($subject).'?=',$message,$headers);
}
/**
* Return safe user data.
* @param user id not required
* @return user object or false
*/
public static function user($id=0,$clearCache=false) {
if (!$id&&!Yii::app()->user->isGuest)
$id = Yii::app()->user->id;
if ($id) {
if (!isset(self::$_users[$id])||$clearCache)
self::$_users[$id] = User::model()->with(array('profile'))->findbyPk($id);
return self::$_users[$id];
} else return false;
}
/**
* Return safe user data.
* @param user name
* @return user object or false
*/
public static function getUserByName($username) {
if (!isset(self::$_userByName[$username])) {
$_userByName[$username] = User::model()->findByAttributes(array('username'=>$username));
}
return $_userByName[$username];
}
/**
* Return safe user data.
* @param user id not required
* @return user object or false
*/
public function users() {
return User;
}
}