2012-09-20 19:38:42 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
class UsuarioController extends Controller {
|
|
|
|
|
|
2012-09-24 23:14:37 +00:00
|
|
|
public $defaultAction = 'modificar';
|
|
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
/**
|
|
|
|
|
* @return array action filters
|
|
|
|
|
*/
|
|
|
|
|
public function filters() {
|
|
|
|
|
return array(
|
|
|
|
|
'accessControl', // perform access control for CRUD operations
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Specifies the access control rules.
|
|
|
|
|
* This method is used by the 'accessControl' filter.
|
|
|
|
|
* @return array access control rules
|
|
|
|
|
*/
|
|
|
|
|
public function accessRules() {
|
|
|
|
|
return array(
|
|
|
|
|
array('allow', // allow admin user to perform 'admin' and 'delete' actions
|
2012-10-02 19:36:18 +00:00
|
|
|
'actions' => array('modificar', 'delete'),
|
2012-09-20 19:38:42 +00:00
|
|
|
'users' => array('@'),
|
|
|
|
|
),
|
|
|
|
|
array('deny', // deny all users
|
|
|
|
|
'users' => array('*'),
|
|
|
|
|
),
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* 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
|
|
|
|
|
*/
|
2012-09-28 18:30:16 +00:00
|
|
|
public function actionModificar($id, $provider = '') {
|
2012-09-21 16:06:20 +00:00
|
|
|
if ($id != Yii::app()->user->id)
|
2012-09-24 23:14:37 +00:00
|
|
|
throw new CHttpException(404, Yii::t('profind', 'La página solicitada no existe.'));
|
|
|
|
|
|
2012-09-28 18:30:16 +00:00
|
|
|
if (($provider != '') && (!isset($_POST['Usuario']))) {
|
|
|
|
|
switch ($provider) {
|
2012-09-29 18:15:28 +00:00
|
|
|
case 'Twitter':
|
|
|
|
|
case 'Facebook':
|
|
|
|
|
case 'LinkedIn':
|
2012-09-28 18:30:16 +00:00
|
|
|
$usuario = $this->loadModelwithSocialData($id, $provider);
|
|
|
|
|
break;
|
|
|
|
|
default:
|
|
|
|
|
throw new CHttpException(404, Yii::t('profind', 'La página solicitada no existe.'));
|
|
|
|
|
}
|
|
|
|
|
}
|
2012-09-29 18:15:28 +00:00
|
|
|
else
|
2012-09-28 18:30:16 +00:00
|
|
|
$usuario = $this->loadModel($id);
|
|
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
// Uncomment the following line if AJAX validation is needed
|
2012-09-26 11:07:00 +00:00
|
|
|
// $this->performAjaxValidation($usuario);
|
2012-09-20 19:38:42 +00:00
|
|
|
|
|
|
|
|
if (isset($_POST['Usuario'])) {
|
2012-09-26 11:07:00 +00:00
|
|
|
$usuario->attributes = $_POST['Usuario'];
|
|
|
|
|
$ficheroFotografia = CUploadedFile::getInstance($usuario, 'ficheroFotografia');
|
2012-10-01 15:38:32 +00:00
|
|
|
|
|
|
|
|
Yii::log(CVarDumper::dumpAsString($_POST['Usuario']), CLogger::LEVEL_ERROR);
|
|
|
|
|
Yii::log(CVarDumper::dumpAsString($usuario->attributes), CLogger::LEVEL_ERROR);
|
|
|
|
|
Yii::log(CVarDumper::dumpAsString($ficheroFotografia), CLogger::LEVEL_ERROR);
|
|
|
|
|
|
2012-09-26 11:07:00 +00:00
|
|
|
$quitarFotografia = Yii::app()->request->getParam('quitar_fotografia', '0');
|
2012-09-28 18:30:16 +00:00
|
|
|
|
2012-09-26 11:07:00 +00:00
|
|
|
if ($usuario->save()) {
|
|
|
|
|
if (($quitarFotografia == '1') && ($usuario->fotografia->tieneFotografia()))
|
|
|
|
|
$usuario->fotografia->eliminarFotografia();
|
|
|
|
|
|
|
|
|
|
if ($ficheroFotografia)
|
|
|
|
|
$usuario->fotografia->guardarFotografia($ficheroFotografia);
|
2012-09-28 18:30:16 +00:00
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
Yii::app()->user->setFlash('success', Yii::t('profind', 'Se ha actualizado el perfil'));
|
2012-09-26 11:07:00 +00:00
|
|
|
$this->redirect(array('modificar', 'id' => $usuario->id));
|
2012-09-20 19:38:42 +00:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$this->render('modificar', array(
|
2012-09-26 11:07:00 +00:00
|
|
|
'model' => $usuario,
|
2012-09-20 19:38:42 +00:00
|
|
|
));
|
|
|
|
|
}
|
|
|
|
|
|
2012-10-02 19:36:18 +00:00
|
|
|
public function actionDelete($id) {
|
|
|
|
|
if ($id != Yii::app()->user->id)
|
|
|
|
|
throw new CHttpException(404, Yii::t('profind', 'La página solicitada no existe.'));
|
|
|
|
|
|
|
|
|
|
if (Yii::app()->request->isAjaxRequest) {
|
|
|
|
|
$resultado = array();
|
|
|
|
|
$usuario = $this->loadModel($id);
|
|
|
|
|
|
|
|
|
|
if ($this->enviarMailSolicitudBaja($usuario))
|
|
|
|
|
$resultado['status'] = 'success';
|
|
|
|
|
else
|
|
|
|
|
$resultado['status'] = 'failure';
|
|
|
|
|
|
|
|
|
|
echo function_exists('json_encode') ? json_encode($resultado) : CJSON::encode($resultado);
|
|
|
|
|
Yii::app()->end();
|
|
|
|
|
} else
|
|
|
|
|
$this->redirect($this->createUrl('modificar', array('id' => $id)));
|
|
|
|
|
}
|
|
|
|
|
|
2012-09-28 18:30:16 +00:00
|
|
|
public function loadModelwithSocialData($id, $provider) {
|
|
|
|
|
$usuario = $this->loadModel($id);
|
2012-09-29 18:15:28 +00:00
|
|
|
|
|
|
|
|
if (!Yii::app()->socialConnect->loadUserProfile($provider)) {
|
|
|
|
|
throw new CHttpException(
|
|
|
|
|
Yii::app()->socialConnect->errorCode,
|
|
|
|
|
Yii::t('profind', Yii::app()->socialConnect->errorMessage)
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$profile = Yii::app()->socialConnect->userProfile;
|
|
|
|
|
|
|
|
|
|
//$usuario->email = $profile->email; <-- el email no lo cambio
|
|
|
|
|
$usuario->nombre = $profile->firstName;
|
|
|
|
|
$usuario->apellidos = $profile->lastName;
|
|
|
|
|
$usuario->descripcion = $profile->description;
|
|
|
|
|
|
|
|
|
|
switch ($provider) {
|
|
|
|
|
case 'Twitter':
|
|
|
|
|
$usuario->localidad = $profile->region;
|
|
|
|
|
break;
|
|
|
|
|
case 'Facebook':
|
|
|
|
|
case 'LinkedIn':
|
|
|
|
|
$usuario->localidad = $profile->city;
|
|
|
|
|
break;
|
2012-09-28 18:30:16 +00:00
|
|
|
}
|
2012-09-29 18:15:28 +00:00
|
|
|
|
2012-09-28 18:30:16 +00:00
|
|
|
return $usuario;
|
|
|
|
|
}
|
|
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
/**
|
|
|
|
|
* 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)
|
2012-09-24 23:14:37 +00:00
|
|
|
throw new CHttpException(404, Yii::t('profind', 'La página solicitada no existe.'));
|
2012-09-26 11:07:00 +00:00
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
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();
|
|
|
|
|
}
|
|
|
|
|
}
|
2012-09-28 18:30:16 +00:00
|
|
|
|
2012-10-02 19:36:18 +00:00
|
|
|
/**
|
|
|
|
|
* 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 enviarMailSolicitudBaja($usuario) {
|
|
|
|
|
Yii::import('ext.yii-mail.YiiMailMessage');
|
|
|
|
|
|
|
|
|
|
$url_cancelacion = $this->createAbsoluteUrl('registroUsuario/cancelar', array("key" => $usuario->clave_seguridad, "email" => $usuario->email));
|
|
|
|
|
$mensaje = new YiiMailMessage;
|
|
|
|
|
|
|
|
|
|
$mensaje->from = Yii::app()->params['email_remitente'];
|
|
|
|
|
$mensaje->setTo($usuario->email);
|
|
|
|
|
$mensaje->subject = Yii::t('profind', 'Solicitud de cancelación de su cuenta en PROFIND');
|
|
|
|
|
$mensaje->view = 'solicitud_cancelacion_usuario';
|
|
|
|
|
$mensaje->setBody(array('url' => $url_cancelacion), 'text/html');
|
|
|
|
|
|
|
|
|
|
return Yii::app()->mail->send($mensaje);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2012-09-20 19:38:42 +00:00
|
|
|
}
|