array('index'), 'users' => array('@'), ), array('allow', // allow admin user to perform 'admin' and 'delete' actions 'actions' => array('modificar'), 'users' => array('@'), ), array('allow', // allow admin user to perform 'admin' and 'delete' actions 'actions' => array('index', 'create', 'delete', 'indexEquipo'), 'expression' => 'Usuario::model()->findByPk(Yii::app()->user->id)->id==2', //admin ), array('deny', // deny all users 'users' => array('*'), ), ); } public function actionIndex() { $invitacion = new FormularioInvitarAgente; if (isset($_POST['FormularioInvitarAgente'])) { $invitacion->attributes = $_POST['FormularioInvitarAgente']; if ($invitacion->validate()) { $nuevo_usuario = new Usuario('registrar'); $nuevo_usuario->id_empresa = Yii::app()->user->id_empresa; $nuevo_usuario->tipo = Usuario::TIPO_USUARIO_AGENTE; $nuevo_usuario->nombre = $invitacion->nombre; $nuevo_usuario->email = $invitacion->email; $nuevo_usuario->password = $nuevo_usuario->encrypt(microtime()); $nuevo_usuario->estado = Usuario::ESTADO_NOACTIVO; $nuevo_usuario->clave_seguridad = $nuevo_usuario->encrypt(microtime() . $nuevo_usuario->password); if ($nuevo_usuario->save()) { $this->enviarMailRegistroAgente($nuevo_usuario); Yii::app()->user->setFlash('success', Yii::t('profind', 'Se ha enviado la invitación a la dirección') . ' ' . $invitacion->email); $invitacion = new FormularioInvitarAgente; } else { Yii::app()->user->setFlash('error', Yii::t('profind', 'Se ha producido un error al registrar la invitación')); } } else { Yii::app()->user->setFlash('error', Yii::t('profind', 'Se ha producido un error al validar la invitación')); } } $agentes = Usuario::model()->equipo()->findAll(); if (count($agentes) >= Yii::app()->user->subscripcion->producto->n_agentes) $invitacion = NULL; $this->render('index', array( 'agentes' => $agentes, 'invitacion' => $invitacion, )); } /** * Envía un mail de registro a un usuario * con una URL de confirmación. * @param Usuario $usuario Usuario al que se le enviará el mail de registro */ private function enviarMailRegistroAgente($usuario) { Yii::import('ext.yii-mail.YiiMailMessage'); $url_activacion = Yii::app()->params['frontpage'] . '?' . 'key=' . $usuario->clave_seguridad . '&email=' . urlencode($usuario->email) . '&x=1'; $mensaje = new YiiMailMessage; $mensaje->from = Yii::app()->params['email_remitente']; $mensaje->setTo($usuario->email); $mensaje->subject = Yii::t('profind', 'Complete su registro de agente en PROFIND'); $mensaje->view = 'registro_agente'; $mensaje->setBody(array( 'url' => $url_activacion, 'email' => $usuario->email ), 'text/html' ); Yii::app()->mail->send($mensaje); } /** * Returns the data model based on the primary key given in the GET variable. * If the data model is not found, an HTTP exception will be raised. * @param integer the ID of the model to be loaded */ public function loadModel($id) { $model = Usuario::model()->findByPk($id); if ($model === null) throw new CHttpException(404, Yii::t('profind', 'La página solicitada no existe.')); return $model; } /** * Performs the AJAX validation. * @param CModel the model to be validated */ protected function performAjaxValidation($model) { if (isset($_POST['ajax']) && $_POST['ajax'] === 'usuario-form') { echo CActiveForm::validate($model); Yii::app()->end(); } } }