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('*'), ), ); } /** * Creates a new model. * If creation is successful, the browser will be redirected to the 'view' page. */ public function actionCreate($tipo) { //Yii::import('ext.multimodelform.MultiModelForm'); $model = new Usuario; $model->tipo = $tipo; if ($tipo = 'C') { $model->empresa = new Empresa(); } // Uncomment the following line if AJAX validation is needed // $this->performAjaxValidation($model); if (isset($_POST['Usuario'])) { $model->attributes = $_POST['Usuario']; if ($model->save() && $model->empresa->save()) { //$masterValues = array ('candidato_id'=>$model->id); $this->redirect(array('view', 'id' => $model->id)); } } $this->render('create', array( 'model' => $model, )); } /** * Actualiza un usuario. * If update is successful, the browser will be redirected to the 'view' page. * @param integer $id the ID of the model to be updated */ public function actionModificar($id) { $model = $this->loadModel($id); // Uncomment the following line if AJAX validation is needed // $this->performAjaxValidation($model); if (isset($_POST['Usuario'])) { $model->attributes = $_POST['Usuario']; if ($model->save()) { Yii::app()->user->setFlash('success', Yii::t('profind', 'Se ha actualizado el perfil')); $this->redirect(array('modificar', 'id' => $model->id)); } } $this->render('modificar', array( 'model' => $model, )); } /** * Deletes a particular model. * If deletion is successful, the browser will be redirected to the 'admin' page. * @param integer $id the ID of the model to be deleted */ public function actionDelete($id) { if (Yii::app()->request->isPostRequest) { // we only allow deletion via POST request $this->loadModel($id)->delete(); // if AJAX request (triggered by deletion via admin grid view), we should not redirect the browser if (!isset($_GET['ajax'])) $this->redirect(isset($_POST['returnUrl']) ? $_POST['returnUrl'] : array('admin')); } else throw new CHttpException(400, 'Invalid request. Please do not repeat this request again.'); } public function actionIndex() { $consulta = new CDbCriteria(); $consulta->addCondition('id_empresa = ' . Yii::app()->user->id_empresa); $consulta->addCondition('id != ' . Yii::app()->user->id); $invitacion = new FormularioInvitarAgente; // if it is ajax validation request if (isset($_POST['ajax']) && $_POST['ajax'] === 'invitacion-agente-form') { echo CActiveForm::validate($invitacion); Yii::app()->end(); } 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->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->enviarMailRegistro($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 validad la invitación')); } } $agentes = Usuario::model()->findAll($consulta); $this->render('index', array( 'agentes' => $agentes, 'invitacion' => $invitacion, )); } /** * 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(); } } }