2007-03-29 18:10:14 +02:00
|
|
|
<?php
|
|
|
|
/*******************************************************************************
|
|
|
|
* Copyright (C) 2007 Easter-eggs
|
|
|
|
* http://ldapsaisie.labs.libre-entreprise.org
|
|
|
|
*
|
|
|
|
* Author: See AUTHORS file in top-level directory.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License version 2
|
|
|
|
* as published by the Free Software Foundation.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Gestion des erreurs pour LdapSaisie
|
|
|
|
*
|
2008-04-25 16:09:27 +02:00
|
|
|
* Cette classe gère les retours d'erreurs.
|
2007-03-29 18:10:14 +02:00
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*/
|
|
|
|
class LSerror {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Ajoute une erreur
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @param[in] $code numeric Le code de l'erreur
|
|
|
|
* @param[in] $msg mixed Un tableau ou une chaine pour la construction du message d'erreur
|
|
|
|
* Tableau : '[clef]' => 'valeur'
|
2008-04-25 16:09:27 +02:00
|
|
|
* La clef sera utilisé dans le format de message d'erreur
|
2007-03-29 18:10:14 +02:00
|
|
|
* dans le fichier 'error_code.php'.
|
|
|
|
*
|
|
|
|
* @retval void
|
2008-02-26 18:40:05 +01:00
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function addErrorCode($code=-1,$msg='') {
|
2009-01-21 18:08:09 +01:00
|
|
|
$_SESSION['LSerror'][] = array($code,$msg);
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2009-01-02 17:00:25 +01:00
|
|
|
* Affiche les erreurs
|
2007-03-29 18:10:14 +02:00
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
2009-01-02 17:00:25 +01:00
|
|
|
* @param[in] $return boolean True pour que le texte d'erreurs soit retourné
|
|
|
|
*
|
2007-03-29 18:10:14 +02:00
|
|
|
* @retval void
|
2009-01-02 17:00:25 +01:00
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function display($return=False) {
|
|
|
|
$errors = self::getErrors();
|
2009-01-02 17:00:25 +01:00
|
|
|
if ($errors) {
|
|
|
|
if ($return) {
|
|
|
|
return $errors;
|
|
|
|
}
|
|
|
|
$GLOBALS['Smarty'] -> assign('LSerrors',$errors);
|
|
|
|
}
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
2009-01-02 17:00:25 +01:00
|
|
|
|
2007-03-29 18:10:14 +02:00
|
|
|
/**
|
2009-01-02 17:00:25 +01:00
|
|
|
* Print errors and stop LdapSaisie
|
2007-03-29 18:10:14 +02:00
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
2009-01-02 17:00:25 +01:00
|
|
|
* @param[in] $code Error code (Goto : addErrorCode())
|
|
|
|
* @param[in] $msg Error msg (Goto : addErrorCode())
|
|
|
|
*
|
2007-03-29 18:10:14 +02:00
|
|
|
* @retval void
|
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function stop($code=-1,$msg='') {
|
2009-01-21 18:08:09 +01:00
|
|
|
if(!empty($_SESSION['LSerror'])) {
|
2009-01-02 17:00:25 +01:00
|
|
|
print "<h1>"._('Errors')."</h1>\n";
|
2009-01-21 18:12:29 +01:00
|
|
|
print self::display(true);
|
2008-02-26 18:40:05 +01:00
|
|
|
}
|
2009-01-02 17:00:25 +01:00
|
|
|
print "<h1>"._('Stop')."</h1>\n";
|
2009-01-21 18:12:29 +01:00
|
|
|
exit (self::getError(array($code,$msg)));
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
2008-02-05 17:11:21 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retourne le texte des erreurs
|
2008-02-26 18:40:05 +01:00
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @retvat string Le texte des erreurs
|
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function getErrors() {
|
2009-01-21 18:08:09 +01:00
|
|
|
if(!empty($_SESSION['LSerror'])) {
|
|
|
|
foreach ($_SESSION['LSerror'] as $error) {
|
2009-01-21 18:12:29 +01:00
|
|
|
$txt.=self::getError($error);
|
2008-02-05 17:11:21 +01:00
|
|
|
}
|
2009-01-21 18:12:29 +01:00
|
|
|
self::resetError();
|
2008-02-26 18:40:05 +01:00
|
|
|
return $txt;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2009-01-02 17:00:25 +01:00
|
|
|
/**
|
|
|
|
* Retourne le texte d'une erreur
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @retvat string Le texte des erreurs
|
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function getError($error) {
|
2009-01-02 17:00:25 +01:00
|
|
|
return "(Code ".$error[0].") ".getFData($GLOBALS['LSerror_code'][$error[0]]['msg'],$error[1])."<br />\n";
|
|
|
|
}
|
|
|
|
|
2008-02-26 18:40:05 +01:00
|
|
|
/**
|
2008-04-25 16:09:27 +02:00
|
|
|
* Définir si il y a des erreurs
|
2008-02-26 18:40:05 +01:00
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @retvat boolean
|
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function errorsDefined() {
|
2009-01-21 18:08:09 +01:00
|
|
|
return !empty($_SESSION['LSerror']);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Efface les erreurs sotckés
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @retvat void
|
|
|
|
*/
|
2009-01-21 18:12:29 +01:00
|
|
|
static function resetError() {
|
2009-01-21 18:08:09 +01:00
|
|
|
unset ($_SESSION['LSerror']);
|
2008-02-26 18:40:05 +01:00
|
|
|
}
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
|
|
|
|
2009-01-02 17:00:25 +01:00
|
|
|
/*
|
|
|
|
* Error Codes
|
|
|
|
*/
|
|
|
|
$GLOBALS['LSerror_code']['-1'] = array (
|
|
|
|
'msg' => _("Unknow error!")
|
|
|
|
);
|
|
|
|
$GLOBALS['LSerror_code'][0] = array (
|
|
|
|
'msg' => "%{msg}"
|
|
|
|
);
|
|
|
|
|
2007-11-15 19:07:24 +01:00
|
|
|
?>
|