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 {
|
|
|
|
|
2009-01-25 15:37:03 +01:00
|
|
|
private static $_errorCodes = array(
|
|
|
|
'0' => array('msg' => "%{msg}")
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Défini une erreur
|
|
|
|
*
|
|
|
|
* @author Benjamin Renard <brenard@easter-eggs.com>
|
|
|
|
*
|
|
|
|
* @param[in] $code numeric Le code de l'erreur
|
|
|
|
* @param[in] $msg LSformat Le format paramètrable du message de l'erreur
|
|
|
|
*
|
|
|
|
* @retval void
|
|
|
|
*/
|
|
|
|
public static function defineError($code=-1,$msg='') {
|
|
|
|
self :: $_errorCodes[$code] = array(
|
|
|
|
'msg' => $msg
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2007-03-29 18:10:14 +02:00
|
|
|
/**
|
|
|
|
* 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-25 15:37:03 +01:00
|
|
|
public static function addErrorCode($code=-1,$msg='') {
|
2009-01-21 18:08:09 +01:00
|
|
|
$_SESSION['LSerror'][] = array($code,$msg);
|
2011-04-22 14:30:04 +02:00
|
|
|
LSlog('[ERROR] '.self::getError(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-25 15:37:03 +01:00
|
|
|
public static function display($return=False) {
|
2009-01-21 18:12:29 +01:00
|
|
|
$errors = self::getErrors();
|
2009-01-02 17:00:25 +01:00
|
|
|
if ($errors) {
|
|
|
|
if ($return) {
|
|
|
|
return $errors;
|
|
|
|
}
|
2013-06-17 23:39:22 +02:00
|
|
|
LStemplate :: assign('LSerrors',$errors);
|
2009-01-02 17:00:25 +01:00
|
|
|
}
|
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-25 15:37:03 +01:00
|
|
|
public 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-25 15:37:03 +01:00
|
|
|
public static function getErrors() {
|
2009-01-21 18:08:09 +01:00
|
|
|
if(!empty($_SESSION['LSerror'])) {
|
2012-09-02 19:49:34 +02:00
|
|
|
$txt='';
|
2009-01-21 18:08:09 +01:00
|
|
|
foreach ($_SESSION['LSerror'] as $error) {
|
2011-04-22 14:28:45 +02:00
|
|
|
$txt.=self::getError($error)."<br />\n";
|
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-25 15:37:03 +01:00
|
|
|
private static function getError($error) {
|
2018-06-08 17:41:28 +02:00
|
|
|
return "(Code ".htmlentities($error[0]).") ".htmlentities(getFData(self :: $_errorCodes[$error[0]]['msg'],$error[1]));
|
2009-01-02 17:00:25 +01:00
|
|
|
}
|
|
|
|
|
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-25 15:37:03 +01:00
|
|
|
public 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-25 15:37:03 +01:00
|
|
|
private static function resetError() {
|
2009-01-21 18:08:09 +01:00
|
|
|
unset ($_SESSION['LSerror']);
|
2008-02-26 18:40:05 +01:00
|
|
|
}
|
2009-10-26 00:38:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Check if is Net_LDAP2 error and display possible error message
|
|
|
|
*
|
|
|
|
* @param[in] $data mixed Data
|
|
|
|
*
|
|
|
|
* @retval boolean True if it's an error or False
|
|
|
|
**/
|
2019-03-11 18:17:17 +01:00
|
|
|
public static function isLdapError($data) {
|
2009-10-26 00:38:28 +01:00
|
|
|
if (Net_LDAP2::isError($data)) {
|
|
|
|
LSerror :: addErrorCode(0,$data -> getMessage());
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return;
|
|
|
|
}
|
2014-11-20 12:04:03 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* PHP error handler (see set_error_handler() function doc)
|
|
|
|
**/
|
2019-03-11 18:17:17 +01:00
|
|
|
public static function errorHandler($errno, $errstr, $errfile, $errline) {
|
2014-11-20 12:04:03 +01:00
|
|
|
self :: addErrorCode(-2,"Error ".self :: convertPHPErrorNo($errno)." occured in file $errfile (line : $errline) : $errstr");
|
|
|
|
if ( E_RECOVERABLE_ERROR===$errno ) {
|
|
|
|
throw new ErrorException($errstr, $errno, 0, $errfile, $errline);
|
|
|
|
}
|
|
|
|
return False;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert PHP error number to string
|
|
|
|
*
|
|
|
|
* @param[in] $errno int Error number
|
|
|
|
*
|
|
|
|
* @retval string Corresponding error name
|
|
|
|
**/
|
2019-03-11 18:17:17 +01:00
|
|
|
public static function convertPHPErrorNo($errno) {
|
2014-11-20 12:04:03 +01:00
|
|
|
$error_levels=array (
|
|
|
|
1 => "ERROR",
|
|
|
|
2 => "WARNING",
|
|
|
|
4 => "PARSE",
|
|
|
|
8 => "NOTICE",
|
|
|
|
16 => "CORE_ERROR",
|
|
|
|
32 => "CORE_WARNING",
|
|
|
|
64 => "COMPILE_ERROR",
|
|
|
|
128 => "COMPILE_WARNING",
|
|
|
|
256 => "USER_ERROR",
|
|
|
|
512 => "USER_WARNING",
|
|
|
|
1024 => "USER_NOTICE",
|
|
|
|
2048 => "STRICT",
|
|
|
|
4096 => "RECOVERABLE_ERROR",
|
|
|
|
8192 => "DEPRECATED",
|
|
|
|
16384 => "USER_DEPRECATED",
|
|
|
|
32767 => "ALL",
|
|
|
|
);
|
|
|
|
if (isset($error_levels[$errno])) {
|
|
|
|
return $error_levels[$errno];
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
return "UNKNOWN_ERROR";
|
|
|
|
}
|
|
|
|
}
|
2019-03-11 22:42:20 +01:00
|
|
|
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
|
|
|
|
2009-01-02 17:00:25 +01:00
|
|
|
/*
|
|
|
|
* Error Codes
|
|
|
|
*/
|
2014-11-20 12:04:03 +01:00
|
|
|
LSerror :: defineError(-1,_("Unknown error : %{error}"));
|
|
|
|
LSerror :: defineError(-2,_("PHP error : %{error}"));
|
2019-03-11 22:42:20 +01:00
|
|
|
|