Rev 198 | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php/*vim: set expandtab tabstop=4 shiftwidth=4: */// +------------------------------------------------------------------------------------------------------+// | PHP version 4.1 |// +------------------------------------------------------------------------------------------------------+// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org) |// +------------------------------------------------------------------------------------------------------+// | This library is free software; you can redistribute it and/or |// | modify it under the terms of the GNU Lesser General Public |// | License as published by the Free Software Foundation; either |// | version 2.1 of the License, or (at your option) any later version. |// | |// | This library 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 |// | Lesser General Public License for more details. |// | |// | You should have received a copy of the GNU Lesser General Public |// | License along with this library; if not, write to the Free Software |// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |// +------------------------------------------------------------------------------------------------------+// CVS : $Id: bazar.class.php,v 1.3.2.1 2007-03-07 16:49:21 jp_milcent Exp $/****@package bazar//Auteur original :*@author Alexandre GRANIER <alexandre@tela-botanica.org>*@author Florian Schmitt <florian@ecole-et-nature.org>*@copyright Tela-Botanica 2000-2004*@version $Revision: 1.3.2.1 $// +------------------------------------------------------------------------------------------------------+*/// +------------------------------------------------------------------------------------------------------+// | LES CONSTANTES DES NIVEAUX DE DROIT |// +------------------------------------------------------------------------------------------------------+// +------------------------------------------------------------------------------------------------------+// | ENTETE du PROGRAMME |// +------------------------------------------------------------------------------------------------------+class Administrateur_bazar {var $_auth ;/*** Identifiant de l'utilisateur*/var $_id_utilisateur ;/*** Vaut true si l'utilisateur est un administrateur*/var $_isSuperAdmin ;/** Constructeur** @param object Un objet authentification* @return void**/function Administrateur_bazar (&$AUTH) {$this->_auth = $AUTH ;if ($AUTH->getAuth())$this->_id_utilisateur = $this->_auth->getAuthData(BAZ_CHAMPS_ID) ;}/** isSuperAdmin () - Renvoie true si l'utilisateur est un super administrateur**/function isSuperAdmin() {// On court-circuite si la question a déjà été posé pour ne pas refaire la requeteif (isset ($this->_isSuperAdmin)) return $this->_isSuperAdmin ;// On court-circuite si l'utilisateur n'est pas logguéif (!$this->_auth->getAuth()) return false ;// Sinon on interroge la base$requete = 'SELECT bd_niveau_droit FROM bazar_droits WHERE bd_id_utilisateur='.$this->_id_utilisateur.' AND bd_niveau_droit=0';$resultat = $GLOBALS['_BAZAR_']['db']->query ($requete) ;if (DB::isError($resultat)) {die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;}if ($resultat->numRows() != 0) {$this->_isSuperAdmin = true ;} else {$this->_isSuperAdmin = false ;}return $this->_isSuperAdmin;}/** isAdmin () - Renvoie true si l'utilisateur est administrateur du type de fiche spécifié** @param interger type_annonce Le type de l'annonce**/function isAdmin($id_nature) {// on court-circuite si l'utilisateur n'est pas logguéif (!$this->_auth->getAuth()) return false ;return $this->_requeteDroit ($id_nature, 2) ;}/** isRedacteur() - Renvoie true si l'utilisateur est rédacteur du type de fiche spécifié**/function isRedacteur($id_nature) {return $this->_requeteDroit ($id_nature, 1) ;}/** _requeteDroit() - fait une requete sur la table bazar_droit**/function _requeteDroit ($id_nature, $niveau) {$requete = 'SELECT bd_niveau_droit FROM bazar_droits WHERE bd_id_utilisateur='.$this->_id_utilisateur.' AND bd_id_nature_offre="'.$id_nature.'" and bd_niveau_droit='.$niveau;$resultat = $GLOBALS['_BAZAR_']['db']->query ($requete) ;if (DB::isError($resultat)) {die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;}if ($resultat->numRows() != 0) {return true ;}return false ;}}class Utilisateur_bazar extends Administrateur_bazar {function Utilisateur_bazar($id_utilisateur) {$this->_id_utilisateur = $id_utilisateur ;}function isAdmin($id_nature) {return $this->_requeteDroit ($id_nature, 2) ;}/** isSuperAdmin () - Renvoie true si l'utilisateur est un super administrateur**/function isSuperAdmin() {// On court-circuite si la question a déjà été posé pour ne pas refaire la requeteif (isset ($this->_isSuperAdmin)) return $this->_isSuperAdmin ;// Sinon on interroge la base$requete = 'SELECT bd_niveau_droit FROM bazar_droits WHERE bd_id_utilisateur='.$this->_id_utilisateur.' AND bd_niveau_droit=0';$resultat = $GLOBALS['_BAZAR_']['db']->query ($requete) ;if (DB::isError($resultat)) {die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;}if ($resultat->numRows() != 0) {$this->_isSuperAdmin = true ;} else {$this->_isSuperAdmin = false ;}return $this->_isSuperAdmin;}}/* +--Fin du code ----------------------------------------------------------------------------------------+** $Log: not supported by cvs2svn $* Revision 1.3 2006/03/29 13:05:12 alexandre_tb* ajout de la classe Administrateur_bazar** Revision 1.2 2006/02/09 11:06:12 alexandre_tb* changement dans les id des droit* 0 => super administrateur* 1 => redacteur* 2 => administrateur** Revision 1.1 2006/02/07 11:08:06 alexandre_tb* version initiale** +-- Fin du code ----------------------------------------------------------------------------------------+*/?>