Rev 418 | 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.10 2008-09-17 14:08:45 alexandre_tb 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.10 $// +------------------------------------------------------------------------------------------------------+*/// +------------------------------------------------------------------------------------------------------+// | LES CONSTANTES DES NIVEAUX DE DROIT |// +------------------------------------------------------------------------------------------------------+define ('BAZ_DROIT_SUPER_ADMINISTRATEUR', 0);define ('BAZ_DROIT_ADMINISTRATEUR', 2);define ('BAZ_DROIT_REDACTEUR', 1);// +------------------------------------------------------------------------------------------------------+// | ENTETE du PROGRAMME |// +------------------------------------------------------------------------------------------------------+include_once PAP_CHEMIN_API_PEAR.'PEAR.php';include_once BAZ_CHEMIN_APPLI.'bibliotheque/bazarTemplate.class.php';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() {if(empty($this->_id_utilisateur))return FALSE;// 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)) {return ("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 redacteur du type de fiche specifie**/function isRedacteur($id_nature) {if (isset($GLOBALS['droit_depot']) && $GLOBALS['droit_depot'] == 3) return true;return $this->_requeteDroit ($id_nature, 1) ;}/** _requeteDroit() - fait une requete sur la table bazar_droit**/function _requeteDroit ($id_nature, $niveau) {if(empty($this->_id_utilisateur))return false;$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)) {return ("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() {if(empty($this->_id_utilisateur))return false;// 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)) {return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;}if ($resultat->numRows() != 0) {$this->_isSuperAdmin = true ;} else {$this->_isSuperAdmin = false ;}return $this->_isSuperAdmin;}}define ('BAZAR_NOTIFICATION_NOUVELLE_FICHE', 1);define ('BAZAR_NOTIFICATION_MODIFICATION_FICHE', 2);class bazar extends PEAR {/*** getMailAdmin Renvoie un tableau de mail des administrateurs du type* de fiche passe en parametre** @global DB Un objet DB de PEAR $GLOBALS['_BAZAR_']['db']* @param integer L identifiant de la nature*/function getMailAdmin($id_nature) {$requete = 'select '.BAZ_CHAMPS_EMAIL.' from '.BAZ_ANNUAIRE.', bazar_droits ' .'where bd_id_nature_offre="'.$id_nature.'" and bd_niveau_droit="'.BAZ_DROIT_ADMINISTRATEUR.'"' .' and '.BAZ_CHAMPS_ID.'= bd_id_utilisateur';$resultat = $GLOBALS['_BAZAR_']['db']->query($requete);if (DB::isError($resultat)) $this->raiseError();$tableau_mail = array();if ($resultat->numRows() == 0) return false;while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {array_push ($tableau_mail, $ligne[BAZ_CHAMPS_EMAIL]) ;}return $tableau_mail;}/*** getMailAdmin Renvoie un tableau de mail des super administrateurs** @global DB Un objet DB de PEAR $GLOBALS['_BAZAR_']['db']*/function getMailSuperAdmin() {$requete = 'select '.BAZ_CHAMPS_EMAIL.' from '.BAZ_ANNUAIRE.', bazar_droits ' .'where bd_niveau_droit="'.BAZ_DROIT_SUPER_ADMINISTRATEUR.'"' .' and '.BAZ_CHAMPS_ID.'= bd_id_utilisateur';$resultat = $GLOBALS['_BAZAR_']['db']->query($requete);if (DB::isError($resultat)) $this->raiseError();$tableau_mail = array();if ($resultat->numRows() == 0) return false;while ($ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC)) {array_push ($tableau_mail, $ligne[BAZ_CHAMPS_EMAIL]) ;}return $tableau_mail;}/*** notifier() envoie un message aux administrateurs** par defaut lors du depot ou de la modification d une fiche*/function notifier($type = BAZAR_NOTIFICATION_NOUVELLE_FICHE) {switch ($type) {case BAZAR_NOTIFICATION_NOUVELLE_FICHE :$id_sujet = BAZ_TEMPLATE_MAIL_NOUVELLE_FICHE_SUJET;$id_corps = BAZ_TEMPLATE_MAIL_NOUVELLE_FICHE_CORPS;break ;case BAZAR_NOTIFICATION_MODIFICATION_FICHE :$id_sujet = BAZ_TEMPLATE_MAIL_MODIFIER_FICHE_SUJET;$id_corps = BAZ_TEMPLATE_MAIL_MODIFIER_FICHE_CORPS;break;}$template = new bazarTemplate($GLOBALS['_BAZAR_']['db']);$sujet = html_entity_decode($template->getTemplate($id_sujet, $GLOBALS['_BAZAR_']['langue'], $GLOBALS['_BAZAR_']['id_typeannonce']));$corps = html_entity_decode($template->getTemplate($id_corps, $GLOBALS['_BAZAR_']['langue'], $GLOBALS['_BAZAR_']['id_typeannonce']));$corps.= $GLOBALS['_BAZAR_']['id_fiche'].'&typeannonce='.$GLOBALS['_BAZAR_']['id_typeannonce'] ;$mails = bazar::getMailSuperAdmin($GLOBALS['_BAZAR_']['id_typeannonce']);if (is_array ($mails)) {foreach ($mails as $mail) {mail ($mail, $sujet, $corps);}}}/** Effectue une requete sur bazar_nature pour remplir diverses* globales** @global string la globale de langue (ex fr-FR)* @global int $GLOBALS['_BAZAR_']['id_typeannonce']** @return mixed true ou PEAR_Error*/function chargeNature() {$requete = 'SELECT bn_label_nature, bn_condition, bn_template, bn_commentaire, bn_appropriation, bn_image_titre, bn_image_logo';$requete .= ' FROM bazar_nature WHERE bn_id_nature = '.$GLOBALS['_BAZAR_']['id_typeannonce'];if (isset($GLOBALS['_BAZAR_']['langue'])) {$requete .= ' and bn_ce_i18n like "'.$GLOBALS['_BAZAR_']['langue'].'%"';}$resultat = $GLOBALS['_BAZAR_']['db']->query($requete) ;if (DB::isError($resultat)) {return $resultat->getMessage().$resultat->getDebugInfo() ;}$ligne = $resultat->fetchRow(DB_FETCHMODE_ASSOC);$GLOBALS['_BAZAR_']['typeannonce']=$ligne['bn_label_nature'];$GLOBALS['_BAZAR_']['condition']=$ligne['bn_condition'];$GLOBALS['_BAZAR_']['template']=$ligne['bn_template'];$GLOBALS['_BAZAR_']['commentaire']=$ligne['bn_commentaire'];$GLOBALS['_BAZAR_']['appropriation']=$ligne['bn_appropriation'];$GLOBALS['_BAZAR_']['image_titre']=$ligne['bn_image_titre'];$GLOBALS['_BAZAR_']['image_logo']=$ligne['bn_image_logo'];return true;}/** Renvoie un element de formulaire de type select ou radio* au vue de filtrer les resultats du bazar* @global mixed $GLOBALS['_BAZAR_']['db'] identifiant de connexion a la bd** @return string html*/function getFiltre($numero_liste, $multiple = false, $type = 'select') {$type == 'select' ? $balise = 'select' : $balise = 'radio' ;// chargement du template$tableau_template = baz_valeurs_template($GLOBALS['_BAZAR_']['template']);$html_filtre = '<select name="bazar_filtre_'.$numero_liste.'" onchange="javascript:this.form.submit();">'."\n";// Requete dans bazar_liste_valeurs$requete = 'select blv_valeur, blv_label from bazar_liste_valeurs where blv_ce_liste="'.$numero_liste.'"';$resultat = $GLOBALS['_BAZAR_']['db']->query($requete);if (DB::isError($resultat)) {return $resultat->getMessage().$resultat->getDebugInfo() ;}$html_filtre .= '<option id="filtre_tous" value="*" ';if (isset($_POST['bazar_filtre_'.$numero_liste]) && '*' == $_POST['bazar_filtre_'.$numero_liste]) {$html_filtre .= 'selected="selected" ';}$html_filtre .= '>'.'Tous les événements'.'</option>';while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {$html_filtre .= '<option class="filtre_'.$ligne->blv_valeur.'" value="'.$ligne->blv_valeur.'"';if (isset($_POST['bazar_filtre_'.$numero_liste]) && $ligne->blv_valeur == $_POST['bazar_filtre_'.$numero_liste]) {$html_filtre .= 'selected="selected" ';}$html_filtre .= '>'.$ligne->blv_label.'</option>'."\n";}$html_filtre .= '</select>'."\n";$resultat->free();return $html_filtre;}function getFiltrePlageDeDate () {if (isset ($_POST['date_debut'])) {$defaut_debut = $_POST['date_debut'];} else {$defaut_debut = '';}if (isset ($_POST['date_fin'])) {$defaut_fin = $_POST['date_fin'];} else {$defaut_fin = '';}$formulaire_filtre .= 'du <input type="text" readonly size="10" name="date_debut" class="inputDate" id="date_debut" value="'.$defaut_debut.'" />';$formulaire_filtre .= ' au <input type="text" readonly size="10" name="date_fin" class="inputDate" id="date_fin" value="'.$defaut_fin.'" />';$formulaire_filtre .= "\n".'<script language="javascript" type="text/javascript">' ."\n".'if (typeof(addListener) != \'function\') {// fonction portable pour ajout de listenersfunction addListener(element, baseName, handler){if (element.addEventListener) {element.addEventListener(baseName, handler, false) ;} else if (element.attachEvent) {element.attachEvent(\'on\'+baseName, handler) ;}}}function verifDate(){if (document.getElementById("date_debut") != null && document.getElementById("date_fin") != null) {this.form.submit() ;}}var calDateFin = document.getElementById("date_fin") ;addListener(calDateFin,\'change\',verifDate) ;var calDateDeb = document.getElementById("date_debut") ;addListener(calDateDeb,\'change\',verifDate) ;$(document).ready(function() { $(\'#date_debut, #date_fin\').datepicker($.extend({}, $.datepicker.regional["fr-FR"],{dateFormat:\'dd-mm-yy\',buttonImage: "client/bazar/images/cal.png",showOn: "both",beforeShow: customRange,buttonImageOnly: true'."\n".'}));})' ."\n".'function customRange(input) { return {minDate: (input.id == "date_fin" ? $("#date_debut").datepicker("getDate") : null),maxDate: (input.id == "date_debut" ? $("#date_fin").datepicker("getDate") : null)};}' ."\n".'</script>';return $formulaire_filtre;}/** Renvoie le formulaire d un filtre* utile dans la carte google ou dans le calendrier** @param string le template avec des filtres ecrits comme {filtre liste="12"}* @global mixed $GLOBALS['_BAZAR_']['url']* @return string html*/function getFormulaireFiltre($template) {if (preg_match_all ('/{filtre liste="([0-9]+)"}/', $template, $subpattern)) {$formulaire_filtre = '<form action="'.$GLOBALS['_BAZAR_']['url']->getURL().'" method="post">'."\n";$formulaire_filtre .= '<fieldset><legend>Filtrer : </legend>';for ($i = 0; $i <count($subpattern[1]); $i++) {$formulaire_filtre .= bazar::getFiltre($subpattern[1][$i]) ;}$formulaire_filtre .= bazar::getFiltrePlageDeDate();$formulaire_filtre .= '<input type="submit" value="Filtrer" />';$formulaire_filtre .= '</fieldset>';$formulaire_filtre .= '</form>'."\n";$html = preg_replace ('/{filtre liste="([0-9]+)"}/', $formulaire_filtre, $template);}return $html;}}class Bazar_element {function &factory($type, $options = false){if (file_exists (BAZ_CHEMIN_APPLI."bibliotheque/elements/{$type}.php")) include_once BAZ_CHEMIN_APPLI."bibliotheque/elements/{$type}.php";else return PEAR::raiseError("Impossible d inclure le fichier /{$type}.php", "Impossible d inclure le fichier ".BAZ_CHEMIN_APPLI."bibliotheque/elements/{$type}.php<br />", null, null,"Impossible d inclure le fichier /{$type}.php", 'PEAR_Error', true);;$classname = "Bazar_{$type}";if (!class_exists($classname)) {$tmp = PEAR::raiseError(null, -2, null, null,"la classe $classname n'existe pas", 'PEAR_Error', true);return $tmp;}@$obj =& new $classname($options);return $obj;}}/* +--Fin du code ----------------------------------------------------------------------------------------+** $Log: bazar.class.php,v $* Revision 1.10 2008-09-17 14:08:45 alexandre_tb* merge depuis aha** Revision 1.9 2007-10-10 13:27:06 alexandre_tb* encodage et remplacement de die en return** Revision 1.8 2007-10-01 10:35:14 alexandre_tb* petit hack pour tester la presence de $GLOBALS['droit_depot'] qui indique le niveau de droit minimum pour pouvoir deposer une fiche.** Revision 1.7 2007-07-04 09:59:09 alexandre_tb* ajout de la classe bazar, premices d une structuration du code** Revision 1.6 2007/04/20 09:58:06 neiluj* correction bug $this->_id_utilisateur** Revision 1.5 2007/04/11 08:30:12 neiluj* remise en état du CVS...** Revision 1.3.2.1 2007/03/07 16:49:21 jp_milcent* Mise en majuscule de select** 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 ----------------------------------------------------------------------------------------+*/?>