Subversion Repositories Applications.papyrus

Rev

Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
448 ddelon 1
<?php
598 ddelon 2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
448 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
// +------------------------------------------------------------------------------------------------------+
598 ddelon 22
// CVS : $Id: projet.class.php,v 1.6 2005-11-14 10:14:30 ddelon Exp $
448 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
598 ddelon 34
*@version       $Revision: 1.6 $
448 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' ;
598 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';
448 ddelon 47
include_once 'Mail.php' ;
48
 
49
// +------------------------------------------------------------------------------------------------------+
50
// |                                            ENTETE du PROGRAMME                                       |
51
// +------------------------------------------------------------------------------------------------------+
52
 
53
 
54
 
55
 
56
/**
57
 * class projet
598 ddelon 58
 *
448 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: ***/
598 ddelon 76
 
448 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;
474 alexandre_ 141
    /**
142
     * Contient le numéro du type du projet
143
     * @access private
144
     */
145
    var $_type;
448 ddelon 146
 
147
    /**
598 ddelon 148
     *
149
     * PHP5
448 ddelon 150
     * @return projet
151
     * @access public
152
     */
481 ddelon 153
    function __construct( &$dbObject,  $id_projet = "")
448 ddelon 154
    {
481 ddelon 155
      $this->projet($dbObject,  $id_projet);
598 ddelon 156
 
448 ddelon 157
    } // end of member function __construct
158
 
159
    /**
160
     *
598 ddelon 161
     *
448 ddelon 162
     * @param DB dbObject Un objet PEAR:DB
163
     * @param int id_projet On passe un identifiant de projet au constructeur. Cela lui permet de faire une
164
     * première requête pour les infos de bases comme le titre, le description etc.
165
     * @return projet
166
     * @access public
167
     */
168
    function projet( &$dbObject,  $id_projet = "")
169
    {
170
        $this->_db = $dbObject ;
171
        if ($id_projet != "") {
172
            $requete = "select * from projet where p_id=$id_projet" ;
173
            $resultat = $this->_db->query ($requete) ;
174
            if (DB::isError($resultat)) {
175
                die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
176
            }
177
            $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
598 ddelon 178
 
448 ddelon 179
            // Affectations dans les propriétés
180
            $this->_id_projet = $ligne->p_id ;
181
            $this->_titre = $ligne->p_titre ;
182
            $this->_description = $ligne->p_description ;
183
            $this->_espace_internet = $ligne->p_espace_internet ;
184
            $this->_date_creation = $ligne->p_date_creation ;
185
            $this->_nom_wikini = $ligne->p_wikini ;
186
            $this->_resume = $ligne->p_resume;
474 alexandre_ 187
            $this->_type = $ligne->p_type ;
448 ddelon 188
            // On récupère le nom du répertoire
189
            $this->_nom_repertoire = $ligne->p_nom_repertoire ;
598 ddelon 190
 
448 ddelon 191
            // on regarde si on a à faire au projet racine
535 alexandre_ 192
            if (PROJET_UTILISE_HIERARCHIE) {
193
	            $requete = 'select  ph_id_projet_pere, ph_id_projet_fils from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
194
	            $resultat = $this->_db->query ($requete) ;
195
	            if (DB::isError ($resultat)) {
196
	                die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
197
	            }
198
	            if (!$resultat->numRows()) {
199
	                $this->_est_racine = true ;
200
	            } else {
201
	                $this->_est_racine = false ;
202
	            }
448 ddelon 203
            }
204
        }
205
    } // end of member function projet
206
 
207
    /**
208
     *
598 ddelon 209
     *
448 ddelon 210
     * @param DB dbObject Un objet PEAR:DB
211
     * @param int id_projet On passe un identifiant de projet au constructeur.
598 ddelon 212
     * @return bool
448 ddelon 213
     * @access public
214
     */
215
    function projetExiste( &$dbObject,  $id_projet)
216
    {
217
        if ($id_projet != "") {
218
            $requete = "select * from projet where p_id=$id_projet" ;
219
            $resultat = $dbObject->query ($requete) ;
220
            if (DB::isError($resultat)) {
221
                die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
222
            }
223
            if ($resultat->numRows() != 0) {
224
                return true ;
225
            }
226
        }
227
    } // end of member function projet
598 ddelon 228
 
448 ddelon 229
    /**
230
     *
598 ddelon 231
     *
232
     * @param int id_projet
448 ddelon 233
     * @return string
234
     * @access public
235
     */
236
    function getTitre( $id_projet = "" )
237
    {
238
        return $this->_titre ;
239
    } // end of member function getTitre
598 ddelon 240
 
448 ddelon 241
    /**
242
     *
598 ddelon 243
     *
448 ddelon 244
     * @return string
245
     * @access public
246
     */
247
    function getResume( )
248
    {
249
        return $this->_resume ;
250
    } // end of member function getResume
251
 
252
    /**
253
     * Renvoie l'identifiant du projet courant.
254
     *
255
     * @return int
256
     * @access public
257
     */
258
    function getId( )
259
    {
260
        return $this->_id_projet ;
261
    } // end of member function getId
262
 
263
    /**
264
     *
598 ddelon 265
     *
448 ddelon 266
     * @return string
267
     * @access public
268
     */
269
    function getDescription( )
270
    {
271
        return $this->_description;
272
    } // end of member function getDescription
273
 
274
    /**
275
     *
598 ddelon 276
     *
448 ddelon 277
     * @return string
278
     * @access public
279
     */
280
    function getEspaceInternet( )
281
    {
282
        return $this->_espace_internet;
283
    } // end of member function getEspaceInternet
284
 
285
    /**
286
     * Charge dans l'objet projet, les listes de discussion
287
     * ['nom_liste']
288
     * ['domaine']
289
     * ['adresse']
290
     *
291
     * @return boolean  true en cas de succès
292
     * @access public
293
     */
294
    function getListesAssociees( )
295
    {
296
        // On rajoute un test pour éviter l'appel SQL si il a déjà été fait une fois
297
        if (count($this->_listes_associes) > 0) return ;
298
        $requete = "select pl_id_liste from projet_lien_liste where pl_id_projet=".$this->_id_projet ;
299
        $resultat = $this->_db->query ($requete) ;
300
        if (DB::isError ($resultat)) {
301
            die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
302
        }
303
        $retour = array() ;
304
        if ($resultat->numRows()) {
305
            $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
306
            $this->_listes_associes[] = new liste_discussion($ligne->pl_id_liste, $this->_db) ;
598 ddelon 307
 
448 ddelon 308
        }
309
    } // end of member function getListesAssociees
310
 
311
    /**
312
     * Renvoie vrai si le projet a au moins une liste
313
     *
314
     * @return bool
315
     * @access public
316
     */
317
    function avoirListe( )
318
    {
319
        $this->getListesAssociees() ;
320
        if (count($this->_listes_associes)) {
321
            return true ;
322
        }
323
        return false ;
324
    } // end of member function isListeExiste
325
 
326
 
327
    /**
328
     * Renvoie la liste des documents associés sous forme d'un tableau, avec les
329
     * informations afférentes. 0 => "nom (cliquable)"
330
     "Taille"
331
     "Date
332
     * de création"          "Proriétaire"          "Visibilité"          "Action
333
     * (cliquable)"
334
     *
335
     * @param visibilite visibilite Si visibilite est à prive, tous les fichiers sont renvoyés ainsi qu'une entrée
598 ddelon 336
     * pour indiquer la visibilité du document.
448 ddelon 337
     * @return Array
338
     * @access public
339
     */
340
    function getListesDocuments( $chemin, $chemin_icones = "icones/" )
341
    {
342
        // On réalise une requete sur projet_documents avec une jointure sur l'annuaire
343
        // et sur gen_type_de_fichier pour envoyer un résultat complet.
344
        // On exclue les fichiers racines cad pd_pere is null
345
        $requete = "select pd_id from projet_documents where pd_ce_projet=".$this->_id_projet.' order by pd_nom' ;
346
        $resultat = $this->_db->query ($requete) ;
347
        if (DB::isError($resultat)) {
348
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
349
        }
350
        $tableau_document = array() ;
598 ddelon 351
 
448 ddelon 352
        // Un compteur
353
        $i = 0 ;
598 ddelon 354
 
448 ddelon 355
        while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
356
            array_push ($tableau_document, new document ($ligne->pd_id, &$this->_db, $chemin, $chemin_icones)) ;
357
        }
358
        return $tableau_document ;
359
    } // end of member function getListesDocuments
360
 
361
 
362
    /**
363
     * Renvoie un tableau avec tous les répertoires d'un projet, imbriqué. ['rep1'],
364
     * ['rep2'] => array (['rep21'], 	['rep22']), etc .
365
     *
366
     * @return Array
367
     * @access public
368
     */
369
    function getListeRepertoireHierarchisee( )
370
    {
371
        // On ne prend que les répertoires
372
        $requete = "select pd_id from projet_documents where pd_ce_projet=".$this->_id_projet.' and pd_ce_type=0 order by pd_nom' ;
373
        $resultat = $this->_db->query ($requete) ;
374
        if (DB::isError($resultat)) {
375
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
376
        }
377
        $tableau_document = array() ;
598 ddelon 378
 
448 ddelon 379
        while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
380
            array_push ($tableau_document, new document ($ligne->pd_id, $this->_db));
381
        }
598 ddelon 382
 
448 ddelon 383
        return $tableau_document ;
384
    } // end of member function getListeRepertoireHierarchisee
385
 
386
 
387
    /**
388
     * Renvoie un tableau comprenant tous les objets projet de la base.
389
     *
390
     * @return Array
391
     * @static
392
     * @access public
393
     */
394
    function getTousLesProjets(&$objetDB)
395
    {
396
        $requete = "select p_id from projet order by p_titre" ;
397
        $resultat = $objetDB->query ($requete) ;
398
        if (DB::isError($resultat)) {
399
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
400
        }
401
        $tableau_resultat = array() ;
402
        while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
403
            array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
404
        }
405
        return $tableau_resultat ;
406
    } // end of member function getTousLesProjets
407
 
408
    /**
474 alexandre_ 409
     * Renvoie un tableau comprenant les objets projet de la base du type $type.
410
     *
411
     * @return Array
412
     * @static
413
     * @access public
414
     */
415
    function getProjetDuType($type, &$objetDB)
416
    {
417
        $requete = "select p_id from projet where p_type=$type order by p_titre" ;
418
        $resultat = $objetDB->query ($requete) ;
419
        if (DB::isError($resultat)) {
420
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
421
        }
422
        $tableau_resultat = array() ;
423
        while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
424
            array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
425
        }
426
        return $tableau_resultat ;
427
    } // end of member function getTousLesProjets
428
 
429
    /**
430
     * Renvoie un le projet racine.
431
     *
432
     * @return projet
433
     * @static
434
     * @access public
435
     */
436
    function getProjetRacine(&$objetDB)
437
    {
438
        $requete = "select p_id from projet where p_id not in (select ph_id_projet_fils from projet_hierarchie)" ;
439
        $resultat = $objetDB->query ($requete) ;
440
        if (DB::isError($resultat)) {
441
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
442
        }
443
        if ($resultat->numRows() == 1) {
444
            $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ;
445
            return new projet($objetDB, $ligne->p_id) ;
446
        }
447
        $tableau_resultat = array() ;
448
        while ($ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT)) {
449
            array_push ($tableau_resultat, new projet ($objetDB, $ligne->p_id)) ;
450
        }
451
        return $tableau_resultat ;
452
    } // end of member function getTousLesProjets
453
 
454
    /**
448 ddelon 455
     * Desctructeur de la classe. Libère la mémoire, ferme les connexions et fichiers.
456
     *
457
     * @return void
458
     * @access public
459
     */
460
    function __destruct( )
461
    {
598 ddelon 462
 
448 ddelon 463
    } // end of member function __destruct
464
 
465
    /**
466
     * Supprime le projet courrant. Il s'ensuit une suppression en cascade de tous les
467
     * éléments liés.
468
     *
469
     * @return void
470
     * @access public
471
     */
472
    function supprimer( )
473
    {
598 ddelon 474
 
448 ddelon 475
    } // end of member function supprimer
476
 
477
    /**
478
     * Permet d'enregistrer une ligne dans la table concernée.
479
     *
480
     * @param Array tableau_de_valeur Le tableau de valeur a insérer dans la base avec pour clé les noms des éléments
481
     * du formulaire.
482
     * @return int
483
     * @access public
484
     */
485
    function enregistrerSQL( $tableau_de_valeur )
486
    {
487
        $nom_repertoire = projet::genereNomRepertoire($tableau_de_valeur['projet_titre'], $this->_db) ;
488
        if (!$this->_creationRepertoire ($nom_repertoire)) {
474 alexandre_ 489
            echo 'Impossible de crée un répertoire'.$nom_repertoire ;
448 ddelon 490
            return false ;
491
        }
474 alexandre_ 492
        // Traitement du type
493
        if (!PROJET_UTILISE_TYPE) {
494
            $tableau_de_valeur['projet_type'] = 0 ;
495
        }
448 ddelon 496
        $id = SQL_obtenirNouveauId($this->_db, 'projet', 'p_id') ;
497
        $requete = 'insert into projet set p_id='.$id ;
481 ddelon 498
        if (!isset($tableau_de_valeur['projet_wikini'])) {
499
        	$tableau_de_valeur['projet_wikini']='';
500
        }
448 ddelon 501
        $requete .= ', p_titre="'.$tableau_de_valeur['projet_titre'].'", p_description="'.$tableau_de_valeur['projet_description'].'"'.
502
                    ', p_espace_internet="'.$tableau_de_valeur['projet_espace_internet'].'", p_date_creation=NOW()'.
474 alexandre_ 503
                    ', p_wikini="'.$tableau_de_valeur['projet_wikini'].'", p_nom_repertoire="'.$nom_repertoire.'", p_resume="'.$tableau_de_valeur['projet_resume'].
504
                    '", p_type='.$tableau_de_valeur['projet_type'] ;
448 ddelon 505
        $resultat = $this->_db->query ($requete) ;
598 ddelon 506
 
448 ddelon 507
        if (DB::isError($resultat)) {
508
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
509
        }
598 ddelon 510
 
535 alexandre_ 511
        // On affecte à l'objet projet son identifiant
512
        $this->_id_projet = $id ;
598 ddelon 513
 
448 ddelon 514
        //insertion dans projet_hiérarchie
535 alexandre_ 515
		if (PROJET_UTILISE_HIERARCHIE) {
516
	        $requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso'].
517
	                    ', ph_id_projet_fils='.$id ;
518
	        $resultat = $this->_db->query ($requete) ;
519
		}
448 ddelon 520
        return true ;
521
    } // end of member function enregistrerSQL
522
 
523
    /**
524
     * Permet de mettre à jour une ligne dans la table concernée.
525
     *
526
     * @param Array tableau_de_valeur Le tableau de valeur a insérer dans la base avec pour clé les noms des éléments
527
     * du formulaire.
528
     * @return int
529
     * @access public
530
     */
531
    function majSQL( $tableau_de_valeur )
532
    {
474 alexandre_ 533
        // Traitement du type
534
        if (!PROJET_UTILISE_TYPE) {
535
            $tableau_de_valeur['projet_type'] = 0 ;
536
        }
448 ddelon 537
        $requete = 'update projet set ';
538
        $requete .= 'p_titre="'.$tableau_de_valeur['projet_titre'].'", p_description="'.$tableau_de_valeur['projet_description'].'"'.
539
                    ', p_espace_internet="'.$tableau_de_valeur['projet_espace_internet'].'"'.
474 alexandre_ 540
                    ', p_resume="'.$tableau_de_valeur['projet_resume'].'", p_type='.$tableau_de_valeur['projet_type'].
448 ddelon 541
                    ' where p_id="'.$this->_id_projet.'"' ;
542
        $resultat = $this->_db->query ($requete) ;
543
        if (DB::isError($resultat)) {
544
            die ("Echec de la requete<br />".$resultat->getMessage()."<br />".$resultat->getDebugInfo()) ;
545
        }
598 ddelon 546
 
535 alexandre_ 547
        if (PROJET_UTILISE_HIERARCHIE) {
548
	        // suppression dans projet_hierarchie
598 ddelon 549
 
535 alexandre_ 550
	        $requete = 'delete from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
551
	        $resultat = $this->_db->query ($requete) ;
598 ddelon 552
 
535 alexandre_ 553
	        //insertion dans projet_hiérarchie
598 ddelon 554
 
535 alexandre_ 555
	        $requete = 'insert into projet_hierarchie set ph_id_projet_pere='.$tableau_de_valeur['projet_asso'].
556
	                    ', ph_id_projet_fils='.$this->_id_projet ;
557
	        $resultat = $this->_db->query ($requete) ;
558
        }
448 ddelon 559
        return true ;
560
    } // end of member function enregistrerSQL
561
 
562
    /**
563
     * Met à jour dans la base de donnée le champs p_nom_wikini
564
     *
565
     * @param int nom_wikini Le nouveau nom wikini
566
     * @return bool
567
     * @access public
568
     */
569
    function majNomWikini( $nom_wikini )
570
    {
571
        $requete = 'update projet set p_wikini="'.$nom_wikini.'" where p_id="'.$this->_id_projet.'"' ;
572
        $resultat = $this->_db->query ($requete) ;
573
        if (DB::isError ($resultat)) {
574
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
575
        }
576
        return true ;
577
    } // end of member function majNomWikini
578
 
579
 
580
    /**
581
     *
598 ddelon 582
     *
583
     * @param string code_sql
448 ddelon 584
     * @return bool
585
     * @access public
586
     */
587
    function suppressionSQL()
588
    {
589
        $msg = '' ;
590
        // Supression du répertoire du projet
591
        if (!$this->_suppression_repertoire()) {
592
            $msg = 'La suppression du répertoire n\'a pas fonctionné' ;
593
        }
594
        // A ajouter la suppression des documents associés
598 ddelon 595
 
448 ddelon 596
        // La suppression des évènements associés
598 ddelon 597
 
448 ddelon 598
        // Le projet lui-même
599
        $requete = "delete from projet where p_id=".$this->_id_projet ;
600
        $resultat = $this->_db->query ($requete) ;
598 ddelon 601
 
535 alexandre_ 602
        if (PROJET_UTILISE_HIERARCHIE) {
603
	        $requete = "delete from projet_hierarchie where ph_id_projet_fils=".$this->_id_projet ;
604
	        $resultat = $this->_db->query ($requete) ;
605
        }
448 ddelon 606
        $requete = "delete from projet_statut_utilisateurs where psu_id_projet=".$this->_id_projet ;
607
        $resultat = $this->_db->query ($requete) ;
608
        return $msg ;
609
    } // end of member function suppressionSQL
610
 
611
    /**
612
     * Supprime le répertoire associé au projet (le répertoire doit être vide).
613
     *
614
     * @return void
615
     * @access private
616
     */
617
    function _suppression_repertoire( )
618
    {
619
        return rmdir ($this->_chemin_repertoire.$this->_nom_repertoire) ;
620
    } // end of member function _suppression_repertoire
621
 
622
    /**
623
     * Permet de créer le répertoire associé au projet.
624
     *
625
     * @param string nom_repertoire Le nom du répertoire à créer.
626
     * @return boolean
627
     * @access private
628
     */
629
    function _creationRepertoire( $nom_repertoire )
630
    {
631
        return mkdir ($this->_chemin_repertoire.$nom_repertoire) ;
632
    } // end of member function _creationRepertoire
633
 
634
    /**
635
     * Permet d'indiquer où seront stockés les fichiers.
636
     *
637
     * @param string cheminRepertoire Le chemin jusqu'au répertoire où seront stockés les fichiers.
638
     * @return void
639
     * @access public
640
     */
641
    function setCheminRepertoire( $cheminRepertoire )
642
    {
643
        $this->_chemin_repertoire = $cheminRepertoire ;
644
    } // end of member function setCheminRepertoire
645
 
646
    /**
647
     * Génère un nom de répertoire à partir de la première lettre de la chaine passé en
648
     * paramètre et de l'identifiant du dernier projet.
649
     *
650
     * @param string chaine Une chaine à partir de laquelle sera générer le nom du répertoire.
651
     * @param DB objetDB un objet PEAR::DB
652
     * @return string
653
     * @static
654
     * @access public
655
     */
656
    function genereNomRepertoire( $chaine, &$objetDB )
657
    {
658
        $requete = "select p_id from projet order by p_id desc limit 0,1" ;
659
        $resultat = $objetDB->query ($requete) ;
660
        if (DB::isError ($resultat)) {
661
            die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
662
        }
481 ddelon 663
        if ($resultat->numRows() > 0) {
664
	        $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
665
	        $nom = strtoupper(substr($chaine, 0, 1)) ;
666
	        $nom .= $ligne->p_id + 1 ;
667
        }
668
	    else {
669
	    	$nom = strtoupper(substr($chaine, 0, 1)) ;
670
	        $nom .=  1 ;
671
	    }
448 ddelon 672
        return $nom ;
598 ddelon 673
 
448 ddelon 674
    } // end of member function genereNomRepertoire
675
 
676
    /**
677
     * Permet de récupérer le nom du répertoire d'un projet.
678
     *
679
     * @return string
680
     * @access public
681
     */
682
    function getNomRepertoire( )
683
    {
684
        return $this->_nom_repertoire ;
685
    } // end of member function getNomRepertoire
686
 
687
    /**
688
     *  Ajoute une liste à un projet
689
     *  Effectue une insertion dans projet_lien_liste
690
     *
691
     * @param liste_discussion liste Une instance de la classe liste_discussion
692
     * @return void
693
     * @access public
694
     */
695
    function ajouterListe( &$liste )
696
    {
697
        $requete = "insert into projet_lien_liste set pl_id_liste=".$liste->getId().
698
                    ', pl_id_projet='.$this->_id_projet ;
699
        $resultat = $this->_db->query ($requete) ;
700
        if (DB::isError ($resultat)) {
701
            die ("Echec de la requete : $requete<br />".$resultat->getMessage()) ;
702
        }
703
    } // end of member function ajouterListe
704
 
705
    /**
706
     * Supprime la liste de discussion associée au projet
707
     *
708
     * @return void
709
     * @access public
710
     */
711
    function supprimerListe(&$liste)
712
    {
713
        $requete = 'delete from projet_lien_liste where pl_id_liste='.$liste->getId() ;
714
        $resultat = $this->_db->query ($requete) ;
715
        if (DB::isError ($resultat)) {
716
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
717
        }
718
        $requete = 'delete from projet_liste where pl_id_liste='.$liste->getId() ;
719
        $resultat = $this->_db->query ($requete) ;
720
        if (DB::isError ($resultat)) {
721
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
722
        }
723
    } // end of member function supprimerListe
724
 
725
 
726
    /**
727
     * Renvoie vrai si le projet est racine.
728
     *
729
     * @return bool
730
     * @access public
731
     */
732
    function isRacine( )
733
    {
734
        return $this->_est_racine ;
735
    } // end of member function isRacine
736
 
737
    /**
738
     * Renvoie le nombre d'inscrits au projet. Effectue une requete dans la table
739
     * projet_statut_utilisateurs
740
     *
741
     * @return int
742
     * @access public
743
     */
744
    function getNombreInscrits( )
745
    {
746
        $requete = 'select count(psu_id_utilisateur) as nbre from projet_statut_utilisateurs where psu_id_projet='.$this->_id_projet ;
747
        $resultat = $this->_db->query ($requete) ;
748
        if (DB::isError ($resultat)) {
749
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
750
        }
751
        $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
752
        return $ligne->nbre ;
753
    } // end of member function getNombreInscrits
754
 
755
 
756
    /**
757
     * Renvoie un tableau contenant les identifiants des fils du projet courant.
758
     *
759
     * @return Array
760
     * @access public
761
     */
762
    function getHierarchie( )
763
    {
764
        $requete = 'select ph_id_projet_fils from projet_hierarchie where ph_id_projet_pere='.$this->_id_projet ;
765
        $resultat = $this->_db->query ($requete) ;
766
        if (DB::isError ($resultat)) {
767
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
768
        }
769
        $tableau_resultat = array() ;
770
        while ($ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT)) {
771
            array_push ($tableau_resultat, $ligne->ph_id_projet_fils) ;
772
        }
773
        return $tableau_resultat ;
774
    } // end of member function getHierarchie
598 ddelon 775
 
448 ddelon 776
    /**
777
     * Renvoie l'identifiant du pere du projet courrant.
778
     *
779
     * @return int
780
     * @access public
781
     */
782
    function getIdPere()
783
    {
784
        $requete = 'select ph_id_projet_pere from projet_hierarchie where ph_id_projet_fils='.$this->_id_projet ;
785
        $resultat = $this->_db->query ($requete) ;
786
        if (DB::isError ($resultat)) {
787
            die ('Echec de la requete : '.$requete.'<br />'.$resultat->getMessage()) ;
788
        }
789
        $tableau_resultat = array() ;
790
        $ligne = $resultat->fetchRow(DB_FETCHMODE_OBJECT) ;
791
        return $ligne->ph_id_projet_pere ;
792
    } // end of member function getIdPere()
793
 
794
    /**
795
     * Renvoie le nom Wiki du wikini associé au projet.
796
     *
797
     * @return string
798
     * @access public
799
     */
800
    function getWikini( )
801
    {
802
        return $this->_nom_wikini ;
803
    } // end of member function getWikini
804
 
474 alexandre_ 805
    /**
806
     * Renvoie le type du projet, ou zéro si le projet n'a pas de type.
807
     *
808
     * @return int
809
     * @access public
810
     */
811
    function getType( )
812
    {
813
        return $this->_type ;
814
    } // end of member function getType
448 ddelon 815
 
816
 
817
 
818
 
474 alexandre_ 819
 
448 ddelon 820
    /**
821
     * initAttributes sets all projet attributes to its default                    value make
822
     * sure to call this method within your class constructor
823
     */
824
    function initAttributes( )
825
    {
826
        $this->chemin_wikini = "projet/wikini/";
827
    }
828
 
829
 
830
} // end of projet
831
?>