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
|
2020-04-29 15:54:21 +02:00
|
|
|
*/
|
2009-01-25 15:37:03 +01:00
|
|
|
public static function defineError($code=-1,$msg='') {
|
|
|
|
self :: $_errorCodes[$code] = array(
|
|
|
|
'msg' => $msg
|
|
|
|
);
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
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
|
2020-04-29 15:54:21 +02:00
|
|
|
* 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
|
2020-04-29 15:54:21 +02: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);
|
2019-06-28 18:00:37 +02:00
|
|
|
if (class_exists('LSlog'))
|
|
|
|
LSlog :: error(self::getError(array($code,$msg)));
|
2007-03-29 18:10:14 +02:00
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
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é
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
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())
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
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;
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
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) {
|
2019-06-17 13:34:02 +02:00
|
|
|
return ($error[0]?"(Code ".htmlentities($error[0]).") ":"").htmlentities(getFData(self :: $_errorCodes[$error[0]]['msg'],$error[1]));
|
2009-01-02 17:00:25 +01:00
|
|
|
}
|
2020-04-29 15:54:21 +02: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']);
|
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2009-01-21 18:08:09 +01:00
|
|
|
/**
|
|
|
|
* 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
|
|
|
}
|
2020-04-29 15:54:21 +02:00
|
|
|
|
2009-10-26 00:38:28 +01:00
|
|
|
/**
|
|
|
|
* Check if is Net_LDAP2 error and display possible error message
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2009-10-26 00:38:28 +01:00
|
|
|
* @param[in] $data mixed Data
|
2020-04-29 15:54:21 +02:00
|
|
|
*
|
2009-10-26 00:38:28 +01:00
|
|
|
* @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
|
|
|
|
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}"));
|