| 2 | ddelon | 1 | <?php
 | 
        
           | 59 | ddelon | 2 | /*vim: set expandtab tabstop=4 shiftwidth=4: */
 | 
        
           | 2 | ddelon | 3 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 4 | // | PHP version 4.1                                                                                      |
 | 
        
           |  |  | 5 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 6 | // | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
 | 
        
           |  |  | 7 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 8 | // | This library is free software; you can redistribute it and/or                                        |
 | 
        
           |  |  | 9 | // | modify it under the terms of the GNU General Public                                                  |
 | 
        
           |  |  | 10 | // | License as published by the Free Software Foundation; either                                         |
 | 
        
           |  |  | 11 | // | version 2.1 of the License, or (at your option) any later version.                                   |
 | 
        
           |  |  | 12 | // |                                                                                                      |
 | 
        
           |  |  | 13 | // | This library is distributed in the hope that it will be useful,                                      |
 | 
        
           |  |  | 14 | // | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
 | 
        
           |  |  | 15 | // | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
 | 
        
           |  |  | 16 | // | General Public License for more details.                                                             |
 | 
        
           |  |  | 17 | // |                                                                                                      |
 | 
        
           |  |  | 18 | // | You should have received a copy of the GNU General Public                                            |
 | 
        
           |  |  | 19 | // | License along with this library; if not, write to the Free Software                                  |
 | 
        
           |  |  | 20 | // | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
 | 
        
           |  |  | 21 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           | 278 | alexandre_ | 22 | // CVS : $Id: projet.class.php,v 1.10.2.1 2008-02-08 08:41:00 alexandre_tb Exp $
 | 
        
           | 2 | ddelon | 23 | /**
 | 
        
           |  |  | 24 | * Application projet
 | 
        
           |  |  | 25 | *
 | 
        
           |  |  | 26 | * La classe projet
 | 
        
           |  |  | 27 | *
 | 
        
           |  |  | 28 | *@package projet
 | 
        
           |  |  | 29 | //Auteur original :
 | 
        
           |  |  | 30 | *@author        Alexandre Granier <alexandre@tela-botanica.org>
 | 
        
           |  |  | 31 | //Autres auteurs :
 | 
        
           |  |  | 32 | *@author        Aucun
 | 
        
           |  |  | 33 | *@copyright     Tela-Botanica 2000-2004
 | 
        
           | 278 | alexandre_ | 34 | *@version       $Revision: 1.10.2.1 $
 | 
        
           | 2 | ddelon | 35 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 36 | */
 | 
        
           |  |  | 37 |   | 
        
           |  |  | 38 |   | 
        
           |  |  | 39 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 40 | // |                                            ENTETE du PROGRAMME                                       |
 | 
        
           |  |  | 41 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 42 |   | 
        
           |  |  | 43 | include_once PROJET_CHEMIN_CLASSES.'document.class.php' ;
 | 
        
           |  |  | 44 | include_once PROJET_CHEMIN_CLASSES.'liste_discussion.class.php' ;
 | 
        
           | 59 | ddelon | 45 | /* Permet la récupération d'un nouvel identifiant d'une table.*/
 | 
        
           |  |  | 46 | require_once PROJET_CHEMIN_BIBLIOTHEQUE_API.'sql/SQL_manipulation.fonct.php';
 | 
        
           | 2 | ddelon | 47 | include_once 'Mail.php' ;
 | 
        
           |  |  | 48 |   | 
        
           |  |  | 49 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 50 | // |                                            ENTETE du PROGRAMME                                       |
 | 
        
           |  |  | 51 | // +------------------------------------------------------------------------------------------------------+
 | 
        
           |  |  | 52 |   | 
        
           |  |  | 53 |   | 
        
           |  |  | 54 |   | 
        
           |  |  | 55 |   | 
        
           |  |  | 56 | /**
 | 
        
           |  |  | 57 |  * class projet
 | 
        
           | 59 | ddelon | 58 |  *
 | 
        
           | 2 | ddelon | 59 |  */
 | 
        
           |  |  | 60 | class projet
 | 
        
           |  |  | 61 | {
 | 
        
           |  |  | 62 |   | 
        
           |  |  | 63 |     /** Aggregations: */
 | 
        
           |  |  | 64 |   | 
        
           |  |  | 65 |     /**
 | 
        
           |  |  | 66 |      * Le tableau d'objet document associés au projet
 | 
        
           |  |  | 67 |      *
 | 
        
           |  |  | 68 |      */
 | 
        
           |  |  | 69 |     var $_documents_associes = array();
 | 
        
           |  |  | 70 |   | 
        
           |  |  | 71 |     var $_listes_associes = array();
 | 
        
           |  |  | 72 |   | 
        
           |  |  | 73 |     /** Compositions: */
 | 
        
           |  |  | 74 |   | 
        
           |  |  | 75 |     /*** Attributes: ***/
 | 
        
           | 59 | ddelon | 76 |   | 
        
           | 2 | ddelon | 77 |     /**
 | 
        
           |  |  | 78 |      * L'identifiant du projet.
 | 
        
           |  |  | 79 |      * @access private
 | 
        
           |  |  | 80 |      */
 | 
        
           |  |  | 81 |     var $_id_projet;
 | 
        
           |  |  | 82 |   | 
        
           |  |  | 83 |     /**
 | 
        
           |  |  | 84 |      * Le titre du projet, tel que dans la base de donnée.
 | 
        
           |  |  | 85 |      * @access private
 | 
        
           |  |  | 86 |      */
 | 
        
           |  |  | 87 |     var $_titre;
 | 
        
           |  |  | 88 |     /**
 | 
        
           |  |  | 89 |      * La description du projet, tel que dans la base.
 | 
        
           |  |  | 90 |      * @access private
 | 
        
           |  |  | 91 |      */
 | 
        
           |  |  | 92 |     var $_description;
 | 
        
           |  |  | 93 |     /**
 | 
        
           |  |  | 94 |      * L'URL d'un site sur le projet. Facultatif.
 | 
        
           |  |  | 95 |      * @access private
 | 
        
           |  |  | 96 |      */
 | 
        
           |  |  | 97 |     var $_espace_internet;
 | 
        
           |  |  | 98 |     /**
 | 
        
           |  |  | 99 |      * Le nom du wikini associé au projet, avec la syntaxe wikini. Vide par défaut.
 | 
        
           |  |  | 100 |      * @access private
 | 
        
           |  |  | 101 |      */
 | 
        
           |  |  | 102 |     var $_nom_wikini;
 | 
        
           |  |  | 103 |     /**
 | 
        
           |  |  | 104 |      * Date de création du projet. A priori ne varie pas dans le temps.
 | 
        
           |  |  | 105 |      * @access private
 | 
        
           |  |  | 106 |      */
 | 
        
           |  |  | 107 |     var $_date_creation;
 | 
        
           |  |  | 108 |     /**
 | 
        
           |  |  | 109 |      * Le chemin relatif vers le répertoire contenant les wikinis.
 | 
        
           |  |  | 110 |      * @access private
 | 
        
           |  |  | 111 |      */
 | 
        
           |  |  | 112 |     var $_chemin_wikini;
 | 
        
           |  |  | 113 |     /**
 | 
        
           |  |  | 114 |      * Une connexion vers la base de donnée.
 | 
        
           |  |  | 115 |      * @access private
 | 
        
           |  |  | 116 |      */
 | 
        
           |  |  | 117 |     var $_db;
 | 
        
           |  |  | 118 |   | 
        
           |  |  | 119 |     /**
 | 
        
           |  |  | 120 |      * Contient le nom du répertoire du projet tel que sur le disque.
 | 
        
           |  |  | 121 |      * @access private
 | 
        
           |  |  | 122 |      */
 | 
        
           |  |  | 123 |     var $_nom_repertoire;
 | 
        
           |  |  | 124 |   | 
        
           |  |  | 125 |     /**
 | 
        
           |  |  | 126 |      * Le chemin jusqu'au répertoire où seront stockés les fichiers.
 | 
        
           |  |  | 127 |      * @access private
 | 
        
           |  |  | 128 |      */
 | 
        
           |  |  | 129 |     var $_chemin_repertoire;
 | 
        
           |  |  | 130 |   | 
        
           |  |  | 131 |     /**
 | 
        
           |  |  | 132 |      * Vaut vrai si le projet est un projet racine et s'il est le seul.
 | 
        
           |  |  | 133 |      * @access private
 | 
        
           |  |  | 134 |      */
 | 
        
           |  |  | 135 |     var $_est_racine;
 | 
        
           |  |  | 136 |     /**
 | 
        
           |  |  | 137 |      * Le résumé du projet
 | 
        
           |  |  | 138 |      * @access private
 | 
        
           |  |  | 139 |      */
 | 
        
           |  |  | 140 |     var $_resume;
 | 
        
           | 11 | alexandre_ | 141 |     /**
 | 
        
           |  |  | 142 |      * Contient le numéro du type du projet
 | 
        
           |  |  | 143 |      * @access private
 | 
        
           |  |  | 144 |      */
 | 
        
           |  |  | 145 |     var $_type;
 | 
        
           | 2 | ddelon | 146 |   | 
        
           | 121 | alexandre_ | 147 | 	/**
 | 
        
           | 208 | neiluj | 148 |      * Indique si l'inscription au projet est moderes
 | 
        
           | 121 | alexandre_ | 149 |      * @access private
 | 
        
           |  |  | 150 |      */
 | 
        
           |  |  | 151 |     var $_isModere;
 | 
        
           | 208 | neiluj | 152 |   | 
        
           |  |  | 153 | 	/**
 | 
        
           |  |  | 154 |      * Indique si le projet a des documents
 | 
        
           |  |  | 155 |      * @access private
 | 
        
           |  |  | 156 |      */
 | 
        
           |  |  | 157 |     var $_avoirDocument;
 | 
        
           |  |  | 158 |   | 
        
           | 2 | ddelon | 159 |     /**
 | 
        
           | 59 | ddelon | 160 |      *
 | 
        
           |  |  | 161 |      * PHP5
 | 
        
           | 2 | ddelon | 162 |      * @return projet
 | 
        
           |  |  | 163 |      * @access public
 | 
        
           |  |  | 164 |      */
 | 
        
           | 15 | ddelon | 165 |     function __construct( &$dbObject,  $id_projet = "")
 | 
        
           | 2 | ddelon | 166 |     {
 | 
        
           | 15 | ddelon | 167 |       $this->projet($dbObject,  $id_projet);
 | 
        
           | 59 | ddelon | 168 |   | 
        
           | 2 | ddelon | 169 |     } // end of member function __construct
 | 
        
           |  |  | 170 |   | 
        
           |  |  | 171 |     /**
 | 
        
           |  |  | 172 |      *
 | 
        
           | 59 | ddelon | 173 |      *
 | 
        
           | 2 | ddelon | 174 |      * @param DB dbObject Un objet PEAR:DB
 | 
        
           |  |  | 175 |      * @param int id_projet On passe un identifiant de projet au constructeur. Cela lui permet de faire une
 | 
        
           |  |  | 176 |      * première requête pour les infos de bases comme le titre, le description etc.
 | 
        
           |  |  | 177 |      * @return projet
 | 
        
           |  |  | 178 |      * @access public
 | 
        
           |  |  | 179 |      */
 | 
        
           |  |  | 180 |     function projet( &$dbObject,  $id_projet = "")
 | 
        
           |  |  | 181 |     {
 | 
        
           |  |  | 182 |         $this->_db = $dbObject ;
 | 
        
           |  |  | 183 |         if ($id_projet != "") {
 | 
        
           |  |  | 184 |             $requete = "select * from projet where p_id=$id_projet" ;
 | 
        
           |  |  | 185 |             $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 186 |             if (DB::isError($resultat)) {
 | 
        
           |  |  | 187 |                 die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 188 |             }
 | 
        
           |  |  | 189 |             $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
 | 
        
           | 59 | ddelon | 190 |   | 
        
           | 2 | ddelon | 191 |             // Affectations dans les propriétés
 | 
        
           |  |  | 192 |             $this->_id_projet = $ligne->p_id ;
 | 
        
           |  |  | 193 |             $this->_titre = $ligne->p_titre ;
 | 
        
           |  |  | 194 |             $this->_description = $ligne->p_description ;
 | 
        
           |  |  | 195 |             $this->_espace_internet = $ligne->p_espace_internet ;
 | 
        
           |  |  | 196 |             $this->_date_creation = $ligne->p_date_creation ;
 | 
        
           |  |  | 197 |             $this->_nom_wikini = $ligne->p_wikini ;
 | 
        
           |  |  | 198 |             $this->_resume = $ligne->p_resume;
 | 
        
           | 11 | alexandre_ | 199 |             $this->_type = $ligne->p_type ;
 | 
        
           | 2 | ddelon | 200 |             // On récupère le nom du répertoire
 | 
        
           |  |  | 201 |             $this->_nom_repertoire = $ligne->p_nom_repertoire ;
 | 
        
           | 121 | alexandre_ | 202 |             $this->_isModere = $ligne->p_modere;
 | 
        
           | 208 | neiluj | 203 | 			$this->_avoirDocument = $ligne->p_avoir_document;
 | 
        
           | 2 | ddelon | 204 |             // on regarde si on a à faire au projet racine
 | 
        
           | 35 | alexandre_ | 205 |             if (PROJET_UTILISE_HIERARCHIE) {
 | 
        
           |  |  | 206 | 	            $requete = 'select  ph_id_projet_pere, ph_id_projet_fils from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
 | 
        
           |  |  | 207 | 	            $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 208 | 	            if (DB::isError ($resultat)) {
 | 
        
           |  |  | 209 | 	                die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
 | 
        
           |  |  | 210 | 	            }
 | 
        
           |  |  | 211 | 	            if (!$resultat->numRows()) {
 | 
        
           |  |  | 212 | 	                $this->_est_racine = true ;
 | 
        
           |  |  | 213 | 	            } else {
 | 
        
           |  |  | 214 | 	                $this->_est_racine = false ;
 | 
        
           |  |  | 215 | 	            }
 | 
        
           | 2 | ddelon | 216 |             }
 | 
        
           |  |  | 217 |         }
 | 
        
           |  |  | 218 |     } // end of member function projet
 | 
        
           |  |  | 219 |   | 
        
           |  |  | 220 |     /**
 | 
        
           |  |  | 221 |      *
 | 
        
           | 59 | ddelon | 222 |      *
 | 
        
           | 2 | ddelon | 223 |      * @param DB dbObject Un objet PEAR:DB
 | 
        
           |  |  | 224 |      * @param int id_projet On passe un identifiant de projet au constructeur.
 | 
        
           | 59 | ddelon | 225 |      * @return bool
 | 
        
           | 2 | ddelon | 226 |      * @access public
 | 
        
           |  |  | 227 |      */
 | 
        
           |  |  | 228 |     function projetExiste( &$dbObject,  $id_projet)
 | 
        
           |  |  | 229 |     {
 | 
        
           |  |  | 230 |         if ($id_projet != "") {
 | 
        
           |  |  | 231 |             $requete = "select * from projet where p_id=$id_projet" ;
 | 
        
           |  |  | 232 |             $resultat = $dbObject->query ($requete) ;
 | 
        
           |  |  | 233 |             if (DB::isError($resultat)) {
 | 
        
           |  |  | 234 |                 die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 235 |             }
 | 
        
           |  |  | 236 |             if ($resultat->numRows() != 0) {
 | 
        
           |  |  | 237 |                 return true ;
 | 
        
           |  |  | 238 |             }
 | 
        
           |  |  | 239 |         }
 | 
        
           |  |  | 240 |     } // end of member function projet
 | 
        
           | 59 | ddelon | 241 |   | 
        
           | 2 | ddelon | 242 |     /**
 | 
        
           |  |  | 243 |      *
 | 
        
           | 59 | ddelon | 244 |      *
 | 
        
           |  |  | 245 |      * @param int id_projet
 | 
        
           | 2 | ddelon | 246 |      * @return string
 | 
        
           |  |  | 247 |      * @access public
 | 
        
           |  |  | 248 |      */
 | 
        
           |  |  | 249 |     function getTitre( $id_projet = "" )
 | 
        
           |  |  | 250 |     {
 | 
        
           |  |  | 251 |         return $this->_titre ;
 | 
        
           |  |  | 252 |     } // end of member function getTitre
 | 
        
           | 59 | ddelon | 253 |   | 
        
           | 2 | ddelon | 254 |     /**
 | 
        
           |  |  | 255 |      *
 | 
        
           | 59 | ddelon | 256 |      *
 | 
        
           | 2 | ddelon | 257 |      * @return string
 | 
        
           |  |  | 258 |      * @access public
 | 
        
           |  |  | 259 |      */
 | 
        
           |  |  | 260 |     function getResume( )
 | 
        
           |  |  | 261 |     {
 | 
        
           |  |  | 262 |         return $this->_resume ;
 | 
        
           |  |  | 263 |     } // end of member function getResume
 | 
        
           |  |  | 264 |   | 
        
           |  |  | 265 |     /**
 | 
        
           |  |  | 266 |      * Renvoie l'identifiant du projet courant.
 | 
        
           |  |  | 267 |      *
 | 
        
           |  |  | 268 |      * @return int
 | 
        
           |  |  | 269 |      * @access public
 | 
        
           |  |  | 270 |      */
 | 
        
           |  |  | 271 |     function getId( )
 | 
        
           |  |  | 272 |     {
 | 
        
           |  |  | 273 |         return $this->_id_projet ;
 | 
        
           |  |  | 274 |     } // end of member function getId
 | 
        
           |  |  | 275 |   | 
        
           |  |  | 276 |     /**
 | 
        
           |  |  | 277 |      *
 | 
        
           | 59 | ddelon | 278 |      *
 | 
        
           | 2 | ddelon | 279 |      * @return string
 | 
        
           |  |  | 280 |      * @access public
 | 
        
           |  |  | 281 |      */
 | 
        
           |  |  | 282 |     function getDescription( )
 | 
        
           |  |  | 283 |     {
 | 
        
           |  |  | 284 |         return $this->_description;
 | 
        
           |  |  | 285 |     } // end of member function getDescription
 | 
        
           |  |  | 286 |   | 
        
           |  |  | 287 |     /**
 | 
        
           |  |  | 288 |      *
 | 
        
           | 59 | ddelon | 289 |      *
 | 
        
           | 2 | ddelon | 290 |      * @return string
 | 
        
           |  |  | 291 |      * @access public
 | 
        
           |  |  | 292 |      */
 | 
        
           |  |  | 293 |     function getEspaceInternet( )
 | 
        
           |  |  | 294 |     {
 | 
        
           |  |  | 295 |         return $this->_espace_internet;
 | 
        
           |  |  | 296 |     } // end of member function getEspaceInternet
 | 
        
           |  |  | 297 |   | 
        
           |  |  | 298 |     /**
 | 
        
           |  |  | 299 |      * Charge dans l'objet projet, les listes de discussion
 | 
        
           |  |  | 300 |      * ['nom_liste']
 | 
        
           |  |  | 301 |      * ['domaine']
 | 
        
           |  |  | 302 |      * ['adresse']
 | 
        
           |  |  | 303 |      *
 | 
        
           |  |  | 304 |      * @return boolean  true en cas de succès
 | 
        
           |  |  | 305 |      * @access public
 | 
        
           |  |  | 306 |      */
 | 
        
           |  |  | 307 |     function getListesAssociees( )
 | 
        
           |  |  | 308 |     {
 | 
        
           |  |  | 309 |         // On rajoute un test pour éviter l'appel SQL si il a déjà été fait une fois
 | 
        
           |  |  | 310 |         if (count($this->_listes_associes) > 0) return ;
 | 
        
           |  |  | 311 |         $requete = "select pl_id_liste from projet_lien_liste where pl_id_projet=".$this->_id_projet ;
 | 
        
           |  |  | 312 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 313 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 314 |             die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
 | 
        
           |  |  | 315 |         }
 | 
        
           |  |  | 316 |         $retour = array() ;
 | 
        
           |  |  | 317 |         if ($resultat->numRows()) {
 | 
        
           |  |  | 318 |             $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
 | 
        
           |  |  | 319 |             $this->_listes_associes[] = new liste_discussion($ligne->pl_id_liste, $this->_db) ;
 | 
        
           | 59 | ddelon | 320 |   | 
        
           | 2 | ddelon | 321 |         }
 | 
        
           |  |  | 322 |     } // end of member function getListesAssociees
 | 
        
           |  |  | 323 |   | 
        
           |  |  | 324 |     /**
 | 
        
           |  |  | 325 |      * Renvoie vrai si le projet a au moins une liste
 | 
        
           |  |  | 326 |      *
 | 
        
           |  |  | 327 |      * @return bool
 | 
        
           |  |  | 328 |      * @access public
 | 
        
           |  |  | 329 |      */
 | 
        
           |  |  | 330 |     function avoirListe( )
 | 
        
           |  |  | 331 |     {
 | 
        
           |  |  | 332 |         $this->getListesAssociees() ;
 | 
        
           |  |  | 333 |         if (count($this->_listes_associes)) {
 | 
        
           |  |  | 334 |             return true ;
 | 
        
           |  |  | 335 |         }
 | 
        
           |  |  | 336 |         return false ;
 | 
        
           | 208 | neiluj | 337 |     }
 | 
        
           | 2 | ddelon | 338 |   | 
        
           | 208 | neiluj | 339 |     /**
 | 
        
           |  |  | 340 |      * Renvoie vrai si le projet a au moins un document, fichier ou repertoire
 | 
        
           |  |  | 341 |      *
 | 
        
           |  |  | 342 |      * Mis en place pour des raisons de performances avant la methode getListesDocuments etait utilisee
 | 
        
           |  |  | 343 |      *
 | 
        
           |  |  | 344 |      * @return bool
 | 
        
           |  |  | 345 |      * @access public
 | 
        
           |  |  | 346 |      */
 | 
        
           |  |  | 347 |     function avoirDocument( )
 | 
        
           |  |  | 348 |     {
 | 
        
           |  |  | 349 |         return $this->_avoirDocument;
 | 
        
           |  |  | 350 |     }
 | 
        
           | 2 | ddelon | 351 |   | 
        
           |  |  | 352 |     /**
 | 
        
           | 208 | neiluj | 353 |      * Permet de fixer la colonne p_avoir_document à 1
 | 
        
           |  |  | 354 |      *
 | 
        
           |  |  | 355 |      * Mis en place pour des raisons de performances avant la methode getListesDocuments etait utilisee
 | 
        
           |  |  | 356 |      *
 | 
        
           |  |  | 357 |      * @param bool
 | 
        
           |  |  | 358 |      * @return mixed true si la requete fonctionne
 | 
        
           |  |  | 359 |      * @access public
 | 
        
           |  |  | 360 |      */
 | 
        
           |  |  | 361 |     function setAvoirDocument($bool)
 | 
        
           |  |  | 362 |     {
 | 
        
           |  |  | 363 |         $val = 0 ;
 | 
        
           |  |  | 364 |         if ($bool) $val = 1;
 | 
        
           |  |  | 365 |         $requete = 'update projet set p_avoir_document='.$val.' where p_id='.$this->_id_projet;
 | 
        
           |  |  | 366 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 367 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 368 |             echo ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 369 |         }
 | 
        
           |  |  | 370 |         return true;
 | 
        
           |  |  | 371 |     }
 | 
        
           |  |  | 372 |   | 
        
           |  |  | 373 |     /**
 | 
        
           | 249 | alexandre_ | 374 |      * Renvoie la liste des documents associes sous forme d'un tableau, avec les
 | 
        
           | 2 | ddelon | 375 |      * informations afférentes. 0 => "nom (cliquable)"
 | 
        
           |  |  | 376 |      "Taille"
 | 
        
           |  |  | 377 |      "Date
 | 
        
           | 249 | alexandre_ | 378 |      * de creation"          "Prorietaire"          "Visibilite"          "Action
 | 
        
           | 2 | ddelon | 379 |      * (cliquable)"
 | 
        
           |  |  | 380 |      *
 | 
        
           | 249 | alexandre_ | 381 |      * @param visibilite visibilite Si visibilite est prive, tous les fichiers sont renvoyes ainsi qu'une entree
 | 
        
           |  |  | 382 |      * pour indiquer la visibilite du document.
 | 
        
           | 2 | ddelon | 383 |      * @return Array
 | 
        
           |  |  | 384 |      * @access public
 | 
        
           |  |  | 385 |      */
 | 
        
           | 249 | alexandre_ | 386 |     function getListesDocuments( $chemin, $chemin_icones = "icones/", $id_repertoire = '' )
 | 
        
           | 2 | ddelon | 387 |     {
 | 
        
           | 249 | alexandre_ | 388 |         // On realise une requete sur projet_documents avec une jointure sur l'annuaire
 | 
        
           |  |  | 389 |         // et sur gen_type_de_fichier pour envoyer un resultat complet.
 | 
        
           | 2 | ddelon | 390 |         // On exclue les fichiers racines cad pd_pere is null
 | 
        
           | 249 | alexandre_ | 391 |         $requete = "select pd_id from projet_documents where pd_ce_projet=".$this->_id_projet ;
 | 
        
           |  |  | 392 |         if ($id_repertoire != '') $requete .= ' and pd_pere='.$id_repertoire;
 | 
        
           |  |  | 393 |         if ($id_repertoire == 0) $requete .= ' and pd_pere=0';
 | 
        
           |  |  | 394 |         $requete .= ' order by pd_nom' ;
 | 
        
           | 2 | ddelon | 395 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 396 |         if (DB::isError($resultat)) {
 | 
        
           | 249 | alexandre_ | 397 |             return ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           | 2 | ddelon | 398 |         }
 | 
        
           |  |  | 399 |         $tableau_document = array() ;
 | 
        
           |  |  | 400 |         // Un compteur
 | 
        
           |  |  | 401 |         $i = 0 ;
 | 
        
           |  |  | 402 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 403 |             array_push ($tableau_document, new document ($ligne->pd_id, &$this->_db, $chemin, $chemin_icones)) ;
 | 
        
           |  |  | 404 |         }
 | 
        
           |  |  | 405 |         return $tableau_document ;
 | 
        
           | 249 | alexandre_ | 406 |     }
 | 
        
           | 2 | ddelon | 407 |   | 
        
           |  |  | 408 |   | 
        
           |  |  | 409 |     /**
 | 
        
           | 249 | alexandre_ | 410 |      * Renvoie un tableau avec tous les repertoires d'un projet, imbrique. ['rep1'],
 | 
        
           | 2 | ddelon | 411 |      * ['rep2'] => array (['rep21'], 	['rep22']), etc .
 | 
        
           |  |  | 412 |      *
 | 
        
           |  |  | 413 |      * @return Array
 | 
        
           |  |  | 414 |      * @access public
 | 
        
           |  |  | 415 |      */
 | 
        
           |  |  | 416 |     function getListeRepertoireHierarchisee( )
 | 
        
           |  |  | 417 |     {
 | 
        
           | 249 | alexandre_ | 418 |         // On ne prend que les repertoires
 | 
        
           |  |  | 419 |         $requete = "select pd_id, pd_pere, pd_nom from projet_documents where pd_ce_projet=".$this->_id_projet.' and pd_ce_type=0 order by pd_nom' ;
 | 
        
           | 2 | ddelon | 420 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 421 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 422 |             die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 423 |         }
 | 
        
           |  |  | 424 |         $tableau_document = array() ;
 | 
        
           | 249 | alexandre_ | 425 | 		/*
 | 
        
           | 2 | ddelon | 426 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 427 |             array_push ($tableau_document, new document ($ligne->pd_id, $this->_db));
 | 
        
           |  |  | 428 |         }
 | 
        
           | 249 | alexandre_ | 429 |         */
 | 
        
           |  |  | 430 |         $tableau = array();
 | 
        
           |  |  | 431 |         $tab = array();
 | 
        
           | 59 | ddelon | 432 |   | 
        
           | 249 | alexandre_ | 433 |   | 
        
           |  |  | 434 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 435 |             array_push ($tableau, array ('id' => $ligne->pd_id,
 | 
        
           |  |  | 436 | 										'id_pere' => $ligne->pd_pere,
 | 
        
           |  |  | 437 | 										'fils' => array(),
 | 
        
           |  |  | 438 | 										'label' => $ligne->pd_nom));
 | 
        
           |  |  | 439 |   | 
        
           |  |  | 440 |         }
 | 
        
           |  |  | 441 |   | 
        
           |  |  | 442 |         // la $tableau reste un tableau de valeur a plat
 | 
        
           |  |  | 443 |   | 
        
           |  |  | 444 |   | 
        
           |  |  | 445 | 		$i = 0;
 | 
        
           |  |  | 446 |         foreach ($tableau as $noeud) {
 | 
        
           |  |  | 447 |         	// On teste si le noeud est racine si oui on l ajoute a l arbre sinon on ne l ajoute pas
 | 
        
           |  |  | 448 |         	if ($noeud['id_pere'] == 0) {
 | 
        
           |  |  | 449 |         		$tab[$i] = $noeud;
 | 
        
           |  |  | 450 |         		$this->construireArbre($tab[$i], $tableau) ;
 | 
        
           |  |  | 451 |         	}
 | 
        
           |  |  | 452 |         	$i++;
 | 
        
           |  |  | 453 |         }
 | 
        
           |  |  | 454 |         return $tab;
 | 
        
           | 2 | ddelon | 455 |     } // end of member function getListeRepertoireHierarchisee
 | 
        
           |  |  | 456 |   | 
        
           | 249 | alexandre_ | 457 | 	function construireArbre(&$noeud, $tableau) {
 | 
        
           |  |  | 458 |     	$j = 0;
 | 
        
           |  |  | 459 |     	foreach ($tableau as $element) {
 | 
        
           |  |  | 460 |         	// pour chaque element on teste
 | 
        
           |  |  | 461 |         	if ($element['id_pere'] == $noeud['id']) {
 | 
        
           |  |  | 462 |         		$noeud['fils'][$j]= $element ;
 | 
        
           |  |  | 463 |         		$this->construireArbre($noeud['fils'][$j],$tableau);
 | 
        
           |  |  | 464 |         	}
 | 
        
           |  |  | 465 |         	$j++;
 | 
        
           |  |  | 466 |         }
 | 
        
           |  |  | 467 |     }
 | 
        
           | 2 | ddelon | 468 |   | 
        
           |  |  | 469 |     /**
 | 
        
           |  |  | 470 |      * Renvoie un tableau comprenant tous les objets projet de la base.
 | 
        
           |  |  | 471 |      *
 | 
        
           |  |  | 472 |      * @return Array
 | 
        
           |  |  | 473 |      * @static
 | 
        
           |  |  | 474 |      * @access public
 | 
        
           |  |  | 475 |      */
 | 
        
           | 208 | neiluj | 476 |     function getTousLesProjets(&$objetDB, $exclu = '')
 | 
        
           | 2 | ddelon | 477 |     {
 | 
        
           | 208 | neiluj | 478 |     	$sql = '';
 | 
        
           | 278 | alexandre_ | 479 |         if (is_object($this) && isset ($this->_projet_exclu) && count($this->_projet_exclu)) {
 | 
        
           | 208 | neiluj | 480 |         	$sql = 'where p_id not in (';
 | 
        
           |  |  | 481 |             foreach ($this->_projet_exclu as $valeur) {
 | 
        
           |  |  | 482 |             	$sql .= $valeur.',' ;
 | 
        
           |  |  | 483 |             }
 | 
        
           |  |  | 484 |             $sql[count($sql)-1] = ')';
 | 
        
           |  |  | 485 |         }
 | 
        
           |  |  | 486 |         $requete = 'select p_id from projet '.$sql.' order by p_titre' ;
 | 
        
           | 2 | ddelon | 487 |         $resultat = $objetDB->query ($requete) ;
 | 
        
           |  |  | 488 |         if (DB::isError($resultat)) {
 | 
        
           | 208 | neiluj | 489 |             echo ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           | 2 | ddelon | 490 |         }
 | 
        
           |  |  | 491 |         $tableau_resultat = array() ;
 | 
        
           |  |  | 492 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 493 |             array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
 | 
        
           |  |  | 494 |         }
 | 
        
           |  |  | 495 |         return $tableau_resultat ;
 | 
        
           |  |  | 496 |     } // end of member function getTousLesProjets
 | 
        
           |  |  | 497 |   | 
        
           |  |  | 498 |     /**
 | 
        
           | 11 | alexandre_ | 499 |      * Renvoie un tableau comprenant les objets projet de la base du type $type.
 | 
        
           |  |  | 500 |      *
 | 
        
           |  |  | 501 |      * @return Array
 | 
        
           |  |  | 502 |      * @static
 | 
        
           |  |  | 503 |      * @access public
 | 
        
           |  |  | 504 |      */
 | 
        
           |  |  | 505 |     function getProjetDuType($type, &$objetDB)
 | 
        
           |  |  | 506 |     {
 | 
        
           |  |  | 507 |         $requete = "select p_id from projet where p_type=$type order by p_titre" ;
 | 
        
           |  |  | 508 |         $resultat = $objetDB->query ($requete) ;
 | 
        
           |  |  | 509 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 510 |             die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 511 |         }
 | 
        
           |  |  | 512 |         $tableau_resultat = array() ;
 | 
        
           |  |  | 513 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 514 |             array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
 | 
        
           |  |  | 515 |         }
 | 
        
           |  |  | 516 |         return $tableau_resultat ;
 | 
        
           |  |  | 517 |     } // end of member function getTousLesProjets
 | 
        
           |  |  | 518 |   | 
        
           |  |  | 519 |     /**
 | 
        
           |  |  | 520 |      * Renvoie un le projet racine.
 | 
        
           |  |  | 521 |      *
 | 
        
           |  |  | 522 |      * @return projet
 | 
        
           |  |  | 523 |      * @static
 | 
        
           |  |  | 524 |      * @access public
 | 
        
           |  |  | 525 |      */
 | 
        
           |  |  | 526 |     function getProjetRacine(&$objetDB)
 | 
        
           |  |  | 527 |     {
 | 
        
           |  |  | 528 |         $requete = "select p_id from projet where p_id not in (select ph_id_projet_fils from projet_hierarchie)" ;
 | 
        
           |  |  | 529 |         $resultat = $objetDB->query ($requete) ;
 | 
        
           |  |  | 530 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 531 |             die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 532 |         }
 | 
        
           |  |  | 533 |         if ($resultat->numRows() == 1) {
 | 
        
           |  |  | 534 |             $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ;
 | 
        
           |  |  | 535 |             return new projet($objetDB, $ligne->p_id) ;
 | 
        
           |  |  | 536 |         }
 | 
        
           |  |  | 537 |         $tableau_resultat = array() ;
 | 
        
           |  |  | 538 |         while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 539 |             array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
 | 
        
           |  |  | 540 |         }
 | 
        
           |  |  | 541 |         return $tableau_resultat ;
 | 
        
           |  |  | 542 |     } // end of member function getTousLesProjets
 | 
        
           |  |  | 543 |   | 
        
           |  |  | 544 |     /**
 | 
        
           | 2 | ddelon | 545 |      * Desctructeur de la classe. Libère la mémoire, ferme les connexions et fichiers.
 | 
        
           |  |  | 546 |      *
 | 
        
           |  |  | 547 |      * @return void
 | 
        
           |  |  | 548 |      * @access public
 | 
        
           |  |  | 549 |      */
 | 
        
           |  |  | 550 |     function __destruct( )
 | 
        
           |  |  | 551 |     {
 | 
        
           | 59 | ddelon | 552 |   | 
        
           | 2 | ddelon | 553 |     } // end of member function __destruct
 | 
        
           |  |  | 554 |   | 
        
           |  |  | 555 |     /**
 | 
        
           |  |  | 556 |      * Supprime le projet courrant. Il s'ensuit une suppression en cascade de tous les
 | 
        
           |  |  | 557 |      * éléments liés.
 | 
        
           |  |  | 558 |      *
 | 
        
           |  |  | 559 |      * @return void
 | 
        
           |  |  | 560 |      * @access public
 | 
        
           |  |  | 561 |      */
 | 
        
           |  |  | 562 |     function supprimer( )
 | 
        
           |  |  | 563 |     {
 | 
        
           | 59 | ddelon | 564 |   | 
        
           | 2 | ddelon | 565 |     } // end of member function supprimer
 | 
        
           |  |  | 566 |   | 
        
           |  |  | 567 |     /**
 | 
        
           |  |  | 568 |      * Permet d'enregistrer une ligne dans la table concernée.
 | 
        
           |  |  | 569 |      *
 | 
        
           |  |  | 570 |      * @param Array tableau_de_valeur Le tableau de valeur a insérer dans la base avec pour clé les noms des éléments
 | 
        
           |  |  | 571 |      * du formulaire.
 | 
        
           |  |  | 572 |      * @return int
 | 
        
           |  |  | 573 |      * @access public
 | 
        
           |  |  | 574 |      */
 | 
        
           |  |  | 575 |     function enregistrerSQL( $tableau_de_valeur )
 | 
        
           |  |  | 576 |     {
 | 
        
           |  |  | 577 |         $nom_repertoire = projet::genereNomRepertoire($tableau_de_valeur['projet_titre'], $this->_db) ;
 | 
        
           |  |  | 578 |         if (!$this->_creationRepertoire ($nom_repertoire)) {
 | 
        
           | 11 | alexandre_ | 579 |             echo 'Impossible de crée un répertoire'.$nom_repertoire ;
 | 
        
           | 2 | ddelon | 580 |             return false ;
 | 
        
           |  |  | 581 |         }
 | 
        
           | 11 | alexandre_ | 582 |         // Traitement du type
 | 
        
           |  |  | 583 |         if (!PROJET_UTILISE_TYPE) {
 | 
        
           |  |  | 584 |             $tableau_de_valeur['projet_type'] = 0 ;
 | 
        
           |  |  | 585 |         }
 | 
        
           | 2 | ddelon | 586 |         $id = SQL_obtenirNouveauId($this->_db, 'projet', 'p_id') ;
 | 
        
           |  |  | 587 |         $requete = 'insert into projet set p_id='.$id ;
 | 
        
           | 15 | ddelon | 588 |         if (!isset($tableau_de_valeur['projet_wikini'])) {
 | 
        
           |  |  | 589 |         	$tableau_de_valeur['projet_wikini']='';
 | 
        
           |  |  | 590 |         }
 | 
        
           | 2 | ddelon | 591 |         $requete .= ', p_titre="'.$tableau_de_valeur['projet_titre'].'", p_description="'.$tableau_de_valeur['projet_description'].'"'.
 | 
        
           |  |  | 592 |                     ', p_espace_internet="'.$tableau_de_valeur['projet_espace_internet'].'", p_date_creation=NOW()'.
 | 
        
           | 11 | alexandre_ | 593 |                     ', p_wikini="'.$tableau_de_valeur['projet_wikini'].'", p_nom_repertoire="'.$nom_repertoire.'", p_resume="'.$tableau_de_valeur['projet_resume'].
 | 
        
           | 121 | alexandre_ | 594 |                     '", p_type='.$tableau_de_valeur['projet_type'].', p_modere="'.$tableau_de_valeur['projet_moderation'].'"' ;
 | 
        
           | 2 | ddelon | 595 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           | 59 | ddelon | 596 |   | 
        
           | 2 | ddelon | 597 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 598 |             die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 599 |         }
 | 
        
           | 59 | ddelon | 600 |   | 
        
           | 35 | alexandre_ | 601 |         // On affecte à l'objet projet son identifiant
 | 
        
           |  |  | 602 |         $this->_id_projet = $id ;
 | 
        
           | 59 | ddelon | 603 |   | 
        
           | 208 | neiluj | 604 |         //insertion dans projet_hierarchie
 | 
        
           | 35 | alexandre_ | 605 | 		if (PROJET_UTILISE_HIERARCHIE) {
 | 
        
           |  |  | 606 | 	        $requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso'].
 | 
        
           |  |  | 607 | 	                    ', ph_id_projet_fils='.$id ;
 | 
        
           |  |  | 608 | 	        $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 609 | 		}
 | 
        
           | 2 | ddelon | 610 |         return true ;
 | 
        
           |  |  | 611 |     } // end of member function enregistrerSQL
 | 
        
           |  |  | 612 |   | 
        
           |  |  | 613 |     /**
 | 
        
           |  |  | 614 |      * Permet de mettre à jour une ligne dans la table concernée.
 | 
        
           |  |  | 615 |      *
 | 
        
           |  |  | 616 |      * @param Array tableau_de_valeur Le tableau de valeur a insérer dans la base avec pour clé les noms des éléments
 | 
        
           |  |  | 617 |      * du formulaire.
 | 
        
           |  |  | 618 |      * @return int
 | 
        
           |  |  | 619 |      * @access public
 | 
        
           |  |  | 620 |      */
 | 
        
           |  |  | 621 |     function majSQL( $tableau_de_valeur )
 | 
        
           |  |  | 622 |     {
 | 
        
           | 11 | alexandre_ | 623 |         // Traitement du type
 | 
        
           |  |  | 624 |         if (!PROJET_UTILISE_TYPE) {
 | 
        
           |  |  | 625 |             $tableau_de_valeur['projet_type'] = 0 ;
 | 
        
           |  |  | 626 |         }
 | 
        
           | 2 | ddelon | 627 |         $requete = 'update projet set ';
 | 
        
           |  |  | 628 |         $requete .= 'p_titre="'.$tableau_de_valeur['projet_titre'].'", p_description="'.$tableau_de_valeur['projet_description'].'"'.
 | 
        
           |  |  | 629 |                     ', p_espace_internet="'.$tableau_de_valeur['projet_espace_internet'].'"'.
 | 
        
           | 11 | alexandre_ | 630 |                     ', p_resume="'.$tableau_de_valeur['projet_resume'].'", p_type='.$tableau_de_valeur['projet_type'].
 | 
        
           | 121 | alexandre_ | 631 |                     ', p_modere='.$tableau_de_valeur['projet_moderation'].
 | 
        
           | 2 | ddelon | 632 |                     ' where p_id="'.$this->_id_projet.'"' ;
 | 
        
           |  |  | 633 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 634 |         if (DB::isError($resultat)) {
 | 
        
           |  |  | 635 |             die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
 | 
        
           |  |  | 636 |         }
 | 
        
           | 59 | ddelon | 637 |   | 
        
           | 35 | alexandre_ | 638 |         if (PROJET_UTILISE_HIERARCHIE) {
 | 
        
           |  |  | 639 | 	        // suppression dans projet_hierarchie
 | 
        
           | 59 | ddelon | 640 |   | 
        
           | 35 | alexandre_ | 641 | 	        $requete = 'delete from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
 | 
        
           |  |  | 642 | 	        $resultat = $this->_db->query ($requete) ;
 | 
        
           | 59 | ddelon | 643 |   | 
        
           | 208 | neiluj | 644 | 	        //insertion dans projet_hierarchie
 | 
        
           | 59 | ddelon | 645 |   | 
        
           | 35 | alexandre_ | 646 | 	        $requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso'].
 | 
        
           |  |  | 647 | 	                    ', ph_id_projet_fils='.$this->_id_projet ;
 | 
        
           |  |  | 648 | 	        $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 649 |         }
 | 
        
           | 2 | ddelon | 650 |         return true ;
 | 
        
           |  |  | 651 |     } // end of member function enregistrerSQL
 | 
        
           |  |  | 652 |   | 
        
           |  |  | 653 |     /**
 | 
        
           |  |  | 654 |      * Met à jour dans la base de donnée le champs p_nom_wikini
 | 
        
           |  |  | 655 |      *
 | 
        
           |  |  | 656 |      * @param int nom_wikini Le nouveau nom wikini
 | 
        
           |  |  | 657 |      * @return bool
 | 
        
           |  |  | 658 |      * @access public
 | 
        
           |  |  | 659 |      */
 | 
        
           |  |  | 660 |     function majNomWikini( $nom_wikini )
 | 
        
           |  |  | 661 |     {
 | 
        
           |  |  | 662 |         $requete = 'update projet set p_wikini="'.$nom_wikini.'" where p_id="'.$this->_id_projet.'"' ;
 | 
        
           |  |  | 663 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 664 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 665 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 666 |         }
 | 
        
           |  |  | 667 |         return true ;
 | 
        
           |  |  | 668 |     } // end of member function majNomWikini
 | 
        
           |  |  | 669 |   | 
        
           |  |  | 670 |   | 
        
           |  |  | 671 |     /**
 | 
        
           |  |  | 672 |      *
 | 
        
           | 59 | ddelon | 673 |      *
 | 
        
           |  |  | 674 |      * @param string code_sql
 | 
        
           | 2 | ddelon | 675 |      * @return bool
 | 
        
           |  |  | 676 |      * @access public
 | 
        
           |  |  | 677 |      */
 | 
        
           |  |  | 678 |     function suppressionSQL()
 | 
        
           |  |  | 679 |     {
 | 
        
           |  |  | 680 |         $msg = '' ;
 | 
        
           |  |  | 681 |         // Supression du répertoire du projet
 | 
        
           |  |  | 682 |         if (!$this->_suppression_repertoire()) {
 | 
        
           | 208 | neiluj | 683 |             $msg = 'La suppression du répertoire n\'a pas fonctionn°' ;
 | 
        
           | 2 | ddelon | 684 |         }
 | 
        
           |  |  | 685 |         // A ajouter la suppression des documents associés
 | 
        
           | 59 | ddelon | 686 |   | 
        
           | 2 | ddelon | 687 |         // La suppression des évènements associés
 | 
        
           | 59 | ddelon | 688 |   | 
        
           | 2 | ddelon | 689 |         // Le projet lui-même
 | 
        
           |  |  | 690 |         $requete = "delete from projet where p_id=".$this->_id_projet ;
 | 
        
           |  |  | 691 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           | 59 | ddelon | 692 |   | 
        
           | 35 | alexandre_ | 693 |         if (PROJET_UTILISE_HIERARCHIE) {
 | 
        
           |  |  | 694 | 	        $requete = "delete from projet_hierarchie where ph_id_projet_fils=".$this->_id_projet ;
 | 
        
           |  |  | 695 | 	        $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 696 |         }
 | 
        
           | 2 | ddelon | 697 |         $requete = "delete from projet_statut_utilisateurs where psu_id_projet=".$this->_id_projet ;
 | 
        
           |  |  | 698 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 699 |         return $msg ;
 | 
        
           |  |  | 700 |     } // end of member function suppressionSQL
 | 
        
           |  |  | 701 |   | 
        
           |  |  | 702 |     /**
 | 
        
           |  |  | 703 |      * Supprime le répertoire associé au projet (le répertoire doit être vide).
 | 
        
           |  |  | 704 |      *
 | 
        
           |  |  | 705 |      * @return void
 | 
        
           |  |  | 706 |      * @access private
 | 
        
           |  |  | 707 |      */
 | 
        
           |  |  | 708 |     function _suppression_repertoire( )
 | 
        
           |  |  | 709 |     {
 | 
        
           |  |  | 710 |         return rmdir ($this->_chemin_repertoire.$this->_nom_repertoire) ;
 | 
        
           |  |  | 711 |     } // end of member function _suppression_repertoire
 | 
        
           |  |  | 712 |   | 
        
           |  |  | 713 |     /**
 | 
        
           |  |  | 714 |      * Permet de créer le répertoire associé au projet.
 | 
        
           |  |  | 715 |      *
 | 
        
           |  |  | 716 |      * @param string nom_repertoire Le nom du répertoire à créer.
 | 
        
           |  |  | 717 |      * @return boolean
 | 
        
           |  |  | 718 |      * @access private
 | 
        
           |  |  | 719 |      */
 | 
        
           |  |  | 720 |     function _creationRepertoire( $nom_repertoire )
 | 
        
           |  |  | 721 |     {
 | 
        
           |  |  | 722 |         return mkdir ($this->_chemin_repertoire.$nom_repertoire) ;
 | 
        
           |  |  | 723 |     } // end of member function _creationRepertoire
 | 
        
           |  |  | 724 |   | 
        
           |  |  | 725 |     /**
 | 
        
           |  |  | 726 |      * Permet d'indiquer où seront stockés les fichiers.
 | 
        
           |  |  | 727 |      *
 | 
        
           |  |  | 728 |      * @param string cheminRepertoire Le chemin jusqu'au répertoire où seront stockés les fichiers.
 | 
        
           |  |  | 729 |      * @return void
 | 
        
           |  |  | 730 |      * @access public
 | 
        
           |  |  | 731 |      */
 | 
        
           |  |  | 732 |     function setCheminRepertoire( $cheminRepertoire )
 | 
        
           |  |  | 733 |     {
 | 
        
           |  |  | 734 |         $this->_chemin_repertoire = $cheminRepertoire ;
 | 
        
           |  |  | 735 |     } // end of member function setCheminRepertoire
 | 
        
           |  |  | 736 |   | 
        
           |  |  | 737 |     /**
 | 
        
           |  |  | 738 |      * Génère un nom de répertoire à partir de la première lettre de la chaine passé en
 | 
        
           |  |  | 739 |      * paramètre et de l'identifiant du dernier projet.
 | 
        
           |  |  | 740 |      *
 | 
        
           |  |  | 741 |      * @param string chaine Une chaine à partir de laquelle sera générer le nom du répertoire.
 | 
        
           |  |  | 742 |      * @param DB objetDB un objet PEAR::DB
 | 
        
           |  |  | 743 |      * @return string
 | 
        
           |  |  | 744 |      * @static
 | 
        
           |  |  | 745 |      * @access public
 | 
        
           |  |  | 746 |      */
 | 
        
           |  |  | 747 |     function genereNomRepertoire( $chaine, &$objetDB )
 | 
        
           |  |  | 748 |     {
 | 
        
           |  |  | 749 |         $requete = "select p_id from projet order by p_id desc limit 0,1" ;
 | 
        
           |  |  | 750 |         $resultat = $objetDB->query ($requete) ;
 | 
        
           |  |  | 751 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 752 |             die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
 | 
        
           |  |  | 753 |         }
 | 
        
           | 15 | ddelon | 754 |         if ($resultat->numRows() > 0) {
 | 
        
           |  |  | 755 | 	        $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
 | 
        
           |  |  | 756 | 	        $nom = strtoupper(substr($chaine, 0, 1)) ;
 | 
        
           |  |  | 757 | 	        $nom .= $ligne->p_id + 1 ;
 | 
        
           |  |  | 758 |         }
 | 
        
           |  |  | 759 | 	    else {
 | 
        
           |  |  | 760 | 	    	$nom = strtoupper(substr($chaine, 0, 1)) ;
 | 
        
           |  |  | 761 | 	        $nom .=  1 ;
 | 
        
           |  |  | 762 | 	    }
 | 
        
           | 2 | ddelon | 763 |         return $nom ;
 | 
        
           | 59 | ddelon | 764 |   | 
        
           | 2 | ddelon | 765 |     } // end of member function genereNomRepertoire
 | 
        
           |  |  | 766 |   | 
        
           |  |  | 767 |     /**
 | 
        
           |  |  | 768 |      * Permet de récupérer le nom du répertoire d'un projet.
 | 
        
           |  |  | 769 |      *
 | 
        
           |  |  | 770 |      * @return string
 | 
        
           |  |  | 771 |      * @access public
 | 
        
           |  |  | 772 |      */
 | 
        
           |  |  | 773 |     function getNomRepertoire( )
 | 
        
           |  |  | 774 |     {
 | 
        
           |  |  | 775 |         return $this->_nom_repertoire ;
 | 
        
           |  |  | 776 |     } // end of member function getNomRepertoire
 | 
        
           |  |  | 777 |   | 
        
           |  |  | 778 |     /**
 | 
        
           |  |  | 779 |      *  Ajoute une liste à un projet
 | 
        
           |  |  | 780 |      *  Effectue une insertion dans projet_lien_liste
 | 
        
           |  |  | 781 |      *
 | 
        
           |  |  | 782 |      * @param liste_discussion liste Une instance de la classe liste_discussion
 | 
        
           |  |  | 783 |      * @return void
 | 
        
           |  |  | 784 |      * @access public
 | 
        
           |  |  | 785 |      */
 | 
        
           |  |  | 786 |     function ajouterListe( &$liste )
 | 
        
           |  |  | 787 |     {
 | 
        
           |  |  | 788 |         $requete = "insert into projet_lien_liste set pl_id_liste=".$liste->getId().
 | 
        
           |  |  | 789 |                     ', pl_id_projet='.$this->_id_projet ;
 | 
        
           |  |  | 790 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 791 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 792 |             die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
 | 
        
           |  |  | 793 |         }
 | 
        
           |  |  | 794 |     } // end of member function ajouterListe
 | 
        
           |  |  | 795 |   | 
        
           |  |  | 796 |     /**
 | 
        
           |  |  | 797 |      * Supprime la liste de discussion associée au projet
 | 
        
           |  |  | 798 |      *
 | 
        
           |  |  | 799 |      * @return void
 | 
        
           |  |  | 800 |      * @access public
 | 
        
           |  |  | 801 |      */
 | 
        
           |  |  | 802 |     function supprimerListe(&$liste)
 | 
        
           |  |  | 803 |     {
 | 
        
           |  |  | 804 |         $requete = 'delete from projet_lien_liste where pl_id_liste='.$liste->getId() ;
 | 
        
           |  |  | 805 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 806 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 807 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 808 |         }
 | 
        
           |  |  | 809 |         $requete = 'delete from projet_liste where pl_id_liste='.$liste->getId() ;
 | 
        
           |  |  | 810 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 811 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 812 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 813 |         }
 | 
        
           |  |  | 814 |     } // end of member function supprimerListe
 | 
        
           |  |  | 815 |   | 
        
           |  |  | 816 |   | 
        
           |  |  | 817 |     /**
 | 
        
           |  |  | 818 |      * Renvoie vrai si le projet est racine.
 | 
        
           |  |  | 819 |      *
 | 
        
           |  |  | 820 |      * @return bool
 | 
        
           |  |  | 821 |      * @access public
 | 
        
           |  |  | 822 |      */
 | 
        
           |  |  | 823 |     function isRacine( )
 | 
        
           |  |  | 824 |     {
 | 
        
           |  |  | 825 |         return $this->_est_racine ;
 | 
        
           |  |  | 826 |     } // end of member function isRacine
 | 
        
           |  |  | 827 |   | 
        
           |  |  | 828 |     /**
 | 
        
           |  |  | 829 |      * Renvoie le nombre d'inscrits au projet. Effectue une requete dans la table
 | 
        
           |  |  | 830 |      * projet_statut_utilisateurs
 | 
        
           |  |  | 831 |      *
 | 
        
           |  |  | 832 |      * @return int
 | 
        
           |  |  | 833 |      * @access public
 | 
        
           |  |  | 834 |      */
 | 
        
           |  |  | 835 |     function getNombreInscrits( )
 | 
        
           |  |  | 836 |     {
 | 
        
           |  |  | 837 |         $requete = 'select count(psu_id_utilisateur) as nbre from projet_statut_utilisateurs where psu_id_projet='.$this->_id_projet ;
 | 
        
           |  |  | 838 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 839 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 840 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 841 |         }
 | 
        
           |  |  | 842 |         $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
 | 
        
           |  |  | 843 |         return $ligne->nbre ;
 | 
        
           |  |  | 844 |     } // end of member function getNombreInscrits
 | 
        
           |  |  | 845 |   | 
        
           |  |  | 846 |   | 
        
           |  |  | 847 |     /**
 | 
        
           |  |  | 848 |      * Renvoie un tableau contenant les identifiants des fils du projet courant.
 | 
        
           |  |  | 849 |      *
 | 
        
           |  |  | 850 |      * @return Array
 | 
        
           |  |  | 851 |      * @access public
 | 
        
           |  |  | 852 |      */
 | 
        
           |  |  | 853 |     function getHierarchie( )
 | 
        
           |  |  | 854 |     {
 | 
        
           |  |  | 855 |         $requete = 'select ph_id_projet_fils from projet_hierarchie where ph_id_projet_pere='.$this->_id_projet ;
 | 
        
           |  |  | 856 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 857 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 858 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 859 |         }
 | 
        
           |  |  | 860 |         $tableau_resultat = array() ;
 | 
        
           |  |  | 861 |         while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
 | 
        
           |  |  | 862 |             array_push ($tableau_resultat, $ligne->ph_id_projet_fils) ;
 | 
        
           |  |  | 863 |         }
 | 
        
           |  |  | 864 |         return $tableau_resultat ;
 | 
        
           |  |  | 865 |     } // end of member function getHierarchie
 | 
        
           | 59 | ddelon | 866 |   | 
        
           | 2 | ddelon | 867 |     /**
 | 
        
           |  |  | 868 |      * Renvoie l'identifiant du pere du projet courrant.
 | 
        
           |  |  | 869 |      *
 | 
        
           |  |  | 870 |      * @return int
 | 
        
           |  |  | 871 |      * @access public
 | 
        
           |  |  | 872 |      */
 | 
        
           |  |  | 873 |     function getIdPere()
 | 
        
           |  |  | 874 |     {
 | 
        
           |  |  | 875 |         $requete = 'select ph_id_projet_pere from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
 | 
        
           |  |  | 876 |         $resultat = $this->_db->query ($requete) ;
 | 
        
           |  |  | 877 |         if (DB::isError ($resultat)) {
 | 
        
           |  |  | 878 |             die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
 | 
        
           |  |  | 879 |         }
 | 
        
           |  |  | 880 |         $tableau_resultat = array() ;
 | 
        
           |  |  | 881 |         $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ;
 | 
        
           |  |  | 882 |         return $ligne->ph_id_projet_pere ;
 | 
        
           |  |  | 883 |     } // end of member function getIdPere()
 | 
        
           |  |  | 884 |   | 
        
           |  |  | 885 |     /**
 | 
        
           |  |  | 886 |      * Renvoie le nom Wiki du wikini associé au projet.
 | 
        
           |  |  | 887 |      *
 | 
        
           |  |  | 888 |      * @return string
 | 
        
           |  |  | 889 |      * @access public
 | 
        
           |  |  | 890 |      */
 | 
        
           |  |  | 891 |     function getWikini( )
 | 
        
           |  |  | 892 |     {
 | 
        
           |  |  | 893 |         return $this->_nom_wikini ;
 | 
        
           |  |  | 894 |     } // end of member function getWikini
 | 
        
           |  |  | 895 |   | 
        
           | 11 | alexandre_ | 896 |     /**
 | 
        
           |  |  | 897 |      * Renvoie le type du projet, ou zéro si le projet n'a pas de type.
 | 
        
           |  |  | 898 |      *
 | 
        
           |  |  | 899 |      * @return int
 | 
        
           |  |  | 900 |      * @access public
 | 
        
           |  |  | 901 |      */
 | 
        
           |  |  | 902 |     function getType( )
 | 
        
           |  |  | 903 |     {
 | 
        
           |  |  | 904 |         return $this->_type ;
 | 
        
           |  |  | 905 |     } // end of member function getType
 | 
        
           | 2 | ddelon | 906 |   | 
        
           | 121 | alexandre_ | 907 | 	/**
 | 
        
           |  |  | 908 |      * Renvoie 1 si les inscriptions au projet sont modérées.
 | 
        
           |  |  | 909 |      *
 | 
        
           |  |  | 910 |      * @return int
 | 
        
           |  |  | 911 |      * @access public
 | 
        
           |  |  | 912 |      */
 | 
        
           |  |  | 913 |     function isModere( )
 | 
        
           |  |  | 914 |     {
 | 
        
           |  |  | 915 |         return $this->_isModere ;
 | 
        
           |  |  | 916 |     } // end of member function getType
 | 
        
           | 2 | ddelon | 917 |   | 
        
           |  |  | 918 |   | 
        
           |  |  | 919 |   | 
        
           |  |  | 920 |     /**
 | 
        
           |  |  | 921 |      * initAttributes sets all projet attributes to its default                    value make
 | 
        
           |  |  | 922 |      * sure to call this method within your class constructor
 | 
        
           |  |  | 923 |      */
 | 
        
           |  |  | 924 |     function initAttributes( )
 | 
        
           |  |  | 925 |     {
 | 
        
           |  |  | 926 |         $this->chemin_wikini = "projet/wikini/";
 | 
        
           |  |  | 927 |     }
 | 
        
           |  |  | 928 |   | 
        
           |  |  | 929 |   | 
        
           |  |  | 930 | } // end of projet
 | 
        
           |  |  | 931 | ?>
 |