extranet/application/controllers/UserController.php

531 lines
16 KiB
PHP
Raw Normal View History

2010-11-22 12:50:12 +00:00
<?php
2011-05-03 12:49:43 +00:00
class UserController extends Zend_Controller_Action
{
2011-05-23 10:04:12 +00:00
/**
* Récupére les valeurs du profil depuis le webservice
* @param unknown_type $login
* @param unknown_type $password
*/
2011-05-03 12:49:43 +00:00
protected function updateProfil($login, $password)
2011-01-05 09:59:49 +00:00
{
2011-05-03 12:49:43 +00:00
Zend_Registry::get('firebug')->info('updateProfil');
$ws = new WsScores();
2013-04-23 09:07:06 +00:00
$utilisateur = new Scores_Utilisateur();
$InfosLogin = $ws->getInfosLogin($login, $_SERVER['REMOTE_ADDR']);
2011-05-03 12:49:43 +00:00
$identity = new stdClass;
$identity->username = $login;
$identity->password = $password;
2011-05-03 12:49:43 +00:00
$identity->email = $InfosLogin->result->email;
$identity->profil = $InfosLogin->result->profil;
$identity->pref = $InfosLogin->result->pref;
$identity->droits = $InfosLogin->result->droits;
$identity->droitsClients = $InfosLogin->result->droitsClients;
$identity->nom = $InfosLogin->result->nom;
$identity->prenom = $InfosLogin->result->prenom;
$identity->tel = $InfosLogin->result->tel;
$identity->fax = $InfosLogin->result->fax;
$identity->mobile = $InfosLogin->result->mobile;
$identity->id = $InfosLogin->result->id;
$identity->idClient = $InfosLogin->result->idClient;
$identity->reference = $InfosLogin->result->reference;
$identity->nbReponses = $InfosLogin->result->nbReponses;
$identity->typeScore = $InfosLogin->result->typeScore;
2013-04-25 12:56:02 +00:00
$identity->dateValidation = $InfosLogin->result->dateValidation;
$identity->nombreConnexions = $InfosLogin->result->nombreConnexions;
$identity->dateDerniereConnexion = $InfosLogin->result->dateDerniereConnexion;
$identity->dateDebutCompte = $InfosLogin->result->dateDebutCompte;
$identity->dateFinCompte = $InfosLogin->result->dateFinCompte;
$identity->ip = $_SERVER['REMOTE_ADDR'];
2011-05-03 12:49:43 +00:00
$identity->timeout = (!empty($InfosLogin->result->timeout)) ?
$InfosLogin->result->timeout : 1800;
$identity->time = time() + $identity->timeout;
2011-05-03 12:49:43 +00:00
$identity->modeEdition = false;
$identity->acceptationCGU = $InfosLogin->result->acceptationCGU;
$lang = in_array($InfosLogin->result->lang,array('fr','en')) ? $InfosLogin->result->lang : 'fr';
$identity->lang = $lang;
$identity->langtmp = $lang;
2013-04-23 09:07:06 +00:00
$identity->browser = $utilisateur->getBrowserInfo();
2011-05-03 12:49:43 +00:00
return $identity;
2011-01-05 09:59:49 +00:00
}
2013-04-23 09:18:59 +00:00
public function init()
2011-05-03 15:58:48 +00:00
{
require_once 'Scores/WsScores.php';
2011-05-23 10:04:12 +00:00
$this->view->headLink()->appendStylesheet('/themes/default/styles/user.css', 'all');
2013-04-23 09:18:59 +00:00
}
2011-05-03 12:49:43 +00:00
/**
* Affiche le fomulaire d'edition des paramètres utilisateur
*/
2010-11-22 12:50:12 +00:00
public function indexAction()
{
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur();
2012-02-29 09:10:51 +00:00
if (!$user->checkPerm('MONPROFIL')){
$this->_forward('perms', 'error');
}
$this->view->assign('device_type', $user->getBrowserInfo()->mobile);
$this->view->assign('browser_info', $user->getBrowserInfo()->name.' '.$user->getBrowserInfo()->version);
2011-05-23 06:45:29 +00:00
$this->view->headLink()->appendStylesheet('/themes/default/styles/form.css', 'all');
$this->view->headScript()->appendFile('/themes/default/scripts/user.js', 'text/javascript');
2011-05-03 12:49:43 +00:00
$request = $this->getRequest();
$messages = '';
$isProfilUpdated = false;
$isPasswordUpdated = false;
2011-05-03 12:49:43 +00:00
$updateResult = false;
2011-04-01 12:14:40 +00:00
$ws = new WsScores();
$login = $request->getParam('login', '');
$op = $request->getParam('op');
//Save data
if ( $request->isPost() ) {
2011-05-03 12:49:43 +00:00
$options = $request->getParam('frmOptions', '');
$action = $options['action'];
2011-08-05 14:40:21 +00:00
if ($login=='') $login = $options['login'];
2011-05-03 12:49:43 +00:00
//Enregistrement des données new & update
if (in_array($action, array('new','update'))) {
2012-06-17 13:38:59 +00:00
2012-07-16 13:25:23 +00:00
if ($options['changepwd']!=1) {
$options['password'] = '';
2011-05-03 12:49:43 +00:00
}
if ( in_array($options['profil'], array('Administrateur', 'SuperAdministrateur'))
&& !in_array('monprofil', $options['droits']) ) {
$options['droits'][] = 'monprofil';
}
2012-07-16 13:25:23 +00:00
if( !isset($options['profil']) ) {
$options['profil'] = 'Utilisateur';
}
2012-06-17 13:38:59 +00:00
2012-07-16 13:25:23 +00:00
$reponse = $ws->setInfosLogin($login, $action, $options);
2011-05-03 12:49:43 +00:00
$isProfilUpdated = true;
$message = 'Erreur lors de la mise à jour du compte !';
if (is_string($reponse)) {
$message = $reponse;
} elseif ($reponse){
2011-05-03 12:49:43 +00:00
$updateResult = true;
$message = 'Compte mis à jour.';
}
}
}
//Liste des catégories des accès
$reponse = $ws->getCategory();
$wscategory = $reponse->item;
$this->view->assign('wscategory', $wscategory);
2011-04-01 12:14:40 +00:00
//Liste de tous les droits
$listeDroits = $ws->getListeDroits();
$droitsLib = array();
foreach($listeDroits->item as $droit) {
2011-05-03 12:49:43 +00:00
$droitsLib[strtoupper($droit->code)] = $droit->desc;
2011-04-01 12:14:40 +00:00
}
$this->view->assign('droitsLib', $droitsLib);
2011-04-01 12:14:40 +00:00
//Liste de toutes les préférences
$listePrefs = $ws->getListePrefs();
$prefsLib = array();
foreach($listePrefs->item as $pref) {
2011-05-03 12:49:43 +00:00
$prefsLib[strtoupper($pref->code)] = $pref->desc;
2011-04-01 12:14:40 +00:00
}
$this->view->assign('prefsLib', $prefsLib);
2011-05-03 12:49:43 +00:00
//Récupération des informations de l'identité
2011-04-01 12:14:40 +00:00
$auth = Zend_Auth::getInstance();
$identity = $auth->getIdentity();
if (isset($options['idClient']) && $identity->idClient == $options['idClient'] && $identity->username == $login) {
//Modification lors du changement de mot de passe
if ($options['changepwd']==1 && $updateResult) {
2011-09-09 08:28:42 +00:00
$identity->password = md5($login.'|'.$options['password']);
$auth->getStorage()->write($identity);
}
//Mise à jour du profil
if ($isProfilUpdated && $updateResult) {
$identity = $this->updateProfil($identity->username, $identity->password);
$auth->getStorage()->write($identity);
}
//Gestion mode edition en SESSION
if ($action=='update') {
$modeEdition = $request->getParam('modeEdition', false);
if ( $modeEdition ) {
$identity->modeEdition = true;
$auth->getStorage()->write($identity);
}
}
}
if ( $isProfilUpdated || $isPasswordUpdated ) {
2011-05-03 12:49:43 +00:00
$this->view->assign('message', $message);
}
2011-02-21 08:45:13 +00:00
$isAdmin = false;
if ( $identity->profil == 'Administrateur'
|| $identity->profil == 'SuperAdministrateur' ) {
2011-02-21 08:45:13 +00:00
$isAdmin = true;
}
$this->view->assign('isAdmin', $isAdmin);
$isSuperAdmin = false;
if ($identity->profil == 'SuperAdministrateur') {
$isSuperAdmin = true;
}
$this->view->assign('isSuperAdmin', $isSuperAdmin);
if ($op=='new')
{
$idClient = $request->getParam('idClient', '');
if ($idClient == '') {
$idClient = $identity->idClient;
}
$reponse = $ws->getNextLogin($idClient);
2011-08-05 14:40:21 +00:00
$options->idClient = $idClient;
if ($identity->idClient!=1 && $identity->profil!='SuperAdministrateur') {
$options->profil = 'Utilisateur';
}
2011-08-05 14:40:21 +00:00
$this->view->assign('options', $options);
$this->view->assign('loginNew', $reponse->result->racine);
$this->view->assign('droitsClients', explode(' ', strtolower($reponse->result->droitsClients)));
2011-08-05 13:19:01 +00:00
$this->view->assign('action', 'new');
$this->view->assign('pref', array());
}
elseif (!empty($op) || $op!='new')
{
if ( !empty($login) && $identity->username != $login ) {
Zend_Registry::get('firebug')->info('getInfosLogin');
$reponse = $ws->getInfosLogin($login, $_SERVER['REMOTE_ADDR']);
$this->view->assign('options', $reponse->result);
$this->view->assign('loginVu', $reponse->result->login);
2011-08-05 13:43:39 +00:00
$this->view->assign('droits', explode(' ', strtolower($reponse->result->droits)));
$this->view->assign('droitsClients', explode(' ', strtolower($reponse->result->droitsClients)));
} else {
$this->view->assign('options', $identity);
$this->view->assign('loginVu', $identity->username);
2011-08-05 13:43:39 +00:00
$this->view->assign('droits', explode(' ', strtolower($identity->droits)));
$this->view->assign('droitsClients', explode(' ', strtolower($identity->droitsClients)));
}
2011-04-01 12:14:40 +00:00
$this->view->assign('loginNew', '');
2011-05-03 12:49:43 +00:00
$this->view->assign('action', 'update');
2011-04-01 12:14:40 +00:00
$this->view->assign('pref', explode(' ',$identity->pref));
}
2010-11-22 12:50:12 +00:00
}
2011-05-23 10:04:12 +00:00
/**
* Téléchargement de la consommation au format CSV
*/
2011-05-23 06:45:29 +00:00
public function consoAction()
{
$this->view->headScript()->appendFile('/themes/default/scripts/conso.js', 'text/javascript');
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur();
$request = $this->getRequest();
$idClient = $request->getParam('idClient', $user->getIdClient());
$login = $request->getParam('login', '');
$this->view->assign('idClient', $idClient);
$this->view->assign('login', $login);
2011-05-23 10:04:12 +00:00
$this->view->assign('profil', $user->getProfil());
2011-05-23 06:45:29 +00:00
}
/**
* Renvoi vers le formulaire utilisateur avec les paramètres de la requete
*/
2011-05-03 15:58:48 +00:00
public function editAction()
{
$params = $this->getRequest()->getParams();
$this->_forward('index', 'user', null, $params);
2011-05-03 15:58:48 +00:00
}
/**
* Suppression d'un utilisateur
*/
2011-05-03 15:58:48 +00:00
public function deleteAction()
{
$request = $this->getRequest();
$login = $request->getParam('login');
$action = 'delete';
$ws = new WsScores();
$ws->setInfosLogin($login, $action);
//Redirect
$this->_forward('liste');
2011-05-03 15:58:48 +00:00
}
/**
* Activation d'un utilisateur
*/
public function enableAction()
2011-05-03 15:58:48 +00:00
{
$request = $this->getRequest();
$login = $request->getParam('login');
$action = 'enable';
$ws = new WsScores();
$ws->setInfosLogin($login, $action);
2011-05-04 13:24:26 +00:00
//Redirect
$this->_forward('liste');
2011-05-03 15:58:48 +00:00
}
/**
* Désactivation d'un utilisateur
*/
public function disableAction()
2011-05-03 15:58:48 +00:00
{
$request = $this->getRequest();
$login = $request->getParam('login');
$action = 'disable';
$ws = new WsScores();
$ws->setInfosLogin($login, $action);
2011-05-04 13:24:26 +00:00
//Redirect
$this->_forward('liste');
2011-05-03 15:58:48 +00:00
}
/**
* Méthode AJAX pour modifier le password d'un utilisateur
*/
2011-04-01 12:14:40 +00:00
public function changepwdAction()
{
2011-05-04 13:24:26 +00:00
//Redirect
2011-04-01 12:14:40 +00:00
}
2011-05-23 10:04:12 +00:00
/**
* Affiche la liste des utiliateurs
*/
public function listeAction()
2011-05-03 15:58:48 +00:00
{
2012-05-20 16:31:28 +00:00
$user = new Scores_Utilisateur();
$request = $this->getRequest();
$idClient = $request->getParam('idClient', $user->getIdClient());
2011-05-03 15:58:48 +00:00
if (!$user->isSuperAdmin() && !$user->isAdmin()) {
2011-09-06 09:12:50 +00:00
$this->renderScript('error/perms.phtml');
2011-05-03 15:58:48 +00:00
}
if ($user->isAdmin()){
$idClient = $user->getIdClient();
}
2011-05-03 15:58:48 +00:00
$ws = new WsScores();
$infos = $ws->getListeUtilisateurs($user->getLogin(), $idClient);
2011-05-03 15:58:48 +00:00
$utilisateurs = $infos->result->item;
$this->view->assign('utilisateurs', $utilisateurs);
$this->view->assign('idClient', $idClient);
2011-05-03 15:58:48 +00:00
}
2011-05-23 10:04:12 +00:00
/**
* Gestion de l'authentification
*/
2011-05-03 15:58:48 +00:00
public function loginAction()
2010-11-22 12:50:12 +00:00
{
$this->view->inlineScript()
2013-02-11 08:25:59 +00:00
->appendFile('/libs/jquery/jquery-1.9.1.min.js')
->appendFile('/libs/jquery/jquery.infieldlabel.min.js');
2011-02-21 08:45:13 +00:00
//@todo : gestion des affichages particuliers pour les clients
2010-11-24 10:55:21 +00:00
$this->view->headTitle()->append('Connexion');
2013-05-16 09:06:39 +00:00
$form = new Application_Form_Login();
2010-11-22 12:50:12 +00:00
$this->view->form = $form;
$request = $this->getRequest();
if ( $request->isPost() ) {
2010-11-22 12:50:12 +00:00
$formData = $request->getPost ();
if ($form->isValid($formData)) {
$login = $form->getValue('login');
$pass = $form->getValue('pass');
$auth = Zend_Auth::getInstance();
$authAdapter = new Scores_AuthAdapter($login, md5($login.'|'.$pass));
2010-11-22 12:50:12 +00:00
$result = $auth->authenticate($authAdapter);
//Auth is valid
if ( $result->isValid() ) {
//Save browser information
$screenSize = $request->getParam('screenSize', 'unknow');
$user = new Scores_Utilisateur();
$info = get_browser();
$isMobile = ($info->ismobiledevice==1) ? 1 : 0;
$user->setBrowserInfo($info->platform, $info->browser, $info->version, $isMobile, $screenSize);
//Get previous url if user has been disconnected
$url = '';
if (Zend_Session::namespaceIsset('login')){
$session = new Zend_Session_Namespace('login');
if (isset($session->url)) {
$url = $session->url;
}
}
if (!empty($url) && $url!='/user/login' && $url!='/user/logout' && $url!='/localauth'){
$this->_redirect($url);
}
$this->_redirect('/');
}
//Auth error
else {
$this->view->message = '';
Zend_Registry::get('firebug')->info($result);
foreach ($result->getMessages() as $message) {
$this->view->message.= $message."<br/>";
}
2010-11-22 12:50:12 +00:00
}
}
}
2011-01-06 11:22:26 +00:00
$this->_helper->layout()->disableLayout();
2010-11-22 12:50:12 +00:00
}
2011-05-23 10:04:12 +00:00
/**
* Gestion de la déconnexion
*/
2011-02-21 08:45:13 +00:00
public function logoutAction()
{
2012-08-23 08:04:46 +00:00
Zend_Auth::getInstance()->clearIdentity();
$this->_helper->layout()->disableLayout();
$request = $this->getRequest();
$message = $request->getParam('message');
$this->view->assign('message', $message);
2012-11-20 14:12:54 +00:00
$ajax = $request->getParam('ajax', 0);
$this->view->assign('ajax', $ajax);
2012-08-23 08:04:46 +00:00
$refresh = 5;
2012-08-23 08:04:46 +00:00
$url = 'http://'.$_SERVER['SERVER_NAME'].$this->view->url(array(
'controller' => 'user',
'action' => 'login',
2012-09-26 20:02:31 +00:00
), null, true);
2012-08-23 08:04:46 +00:00
2011-09-09 08:28:42 +00:00
$this->view->assign('url', $url);
2012-11-20 14:12:54 +00:00
if (!$ajax) {
$this->view->assign('refresh', $refresh);
$this->view->headMeta()->appendHttpEquiv('refresh', $refresh.'; url='.$url);
}
2010-11-22 12:50:12 +00:00
}
2011-11-22 17:00:53 +00:00
/**
* Mettre à jour le mode edition en session sans refresh de la page
*/
public function editionsessionAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
2011-11-22 17:00:53 +00:00
$request = $this->getRequest();
$mode = $request->getParam('mode', 'false');
$auth = Zend_Auth::getInstance();
$identity = $auth->getIdentity();
if ($identity->idClient == 1) {
2011-11-22 17:00:53 +00:00
if ($mode == 'false') {
$identity->modeEdition = false;
echo 0;
} else {
$identity->modeEdition = true;
echo 1;
}
$auth->getStorage()->write($identity);
} else {
echo 0;
2011-11-22 17:00:53 +00:00
}
}
/**
* Override email in surveillance portfolio
*/
public function emailsurveillanceAction()
{
$this->_helper->layout()->disableLayout();
$request = $this->getRequest();
$user = new Scores_Utilisateur();
//Execute webservice operation
if ( $request->isPost() ) {
$email = trim($request->getParam('email'));
if ($user->isAdmin() || $user->isSuperAdmin()) {
$login = $request->getParam('login');
}
if (empty($email)) {
$result = "Aucun email défini!";
} else if (empty($login)) {
$result = "Aucun utilisateur défini!";
} else {
$ws = new WsScores();
$result = $ws->setSurveillancesMail($login, $email);
}
$this->view->assign('result', $result);
}
//Display form in dialog
else {
if ($user->isAdmin() || $user->isSuperAdmin()) {
$login = $request->getParam('login');
} else {
$login = $user->getLogin();
}
$this->view->assign('login', $login);
$this->view->assign('dialog',true);
}
}
2012-02-29 09:05:19 +00:00
/**
* Changer le theme de l'utilisateur
*/
public function changethemeAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
2012-02-29 09:05:19 +00:00
$request = $this->getRequest();
$nom = $request->getParam('nom', 'default');
2012-02-29 09:05:19 +00:00
$auth = Zend_Auth::getInstance();
$identity = $auth->getIdentity();
2012-02-29 09:05:19 +00:00
$identity->theme = $nom;
2012-02-29 09:05:19 +00:00
$auth->getStorage()->write($identity);
2012-02-29 09:05:19 +00:00
//Rediriger vers l'écran de recherche
$this->_redirect('/');
2012-02-29 09:05:19 +00:00
}
/**
* Display browser informations on a simple page
*/
public function browserAction()
{
$this->_helper->layout()->disableLayout();
$this->_helper->viewRenderer->setNoRender(true);
//Load bootstrap
$bootstrap = Zend_Controller_Front::getInstance()->getParam('bootstrap');
//Get useragent and device informations
$userAgent = $bootstrap->getResource('useragent');
$device = $userAgent->getDevice();
//Display
2013-04-18 15:04:49 +00:00
echo "<pre>";
print_r(get_browser());
print_r($device->getAllFeatures());
2013-04-18 15:04:49 +00:00
echo "</pre>";
}
2010-11-22 12:50:12 +00:00
}