Subversion Repositories Applications.papyrus

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
434 ddelon 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
7
// +------------------------------------------------------------------------------------------------------+
8
// | This file is part of Papyrus.                                                                        |
9
// |                                                                                                      |
10
// | Foobar is free software; you can redistribute it and/or modify                                       |
11
// | it under the terms of the GNU General Public License as published by                                 |
12
// | the Free Software Foundation; either version 2 of the License, or                                    |
13
// | (at your option) any later version.                                                                  |
14
// |                                                                                                      |
15
// | Foobar is distributed in the hope that it will be useful,                                            |
16
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
17
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                        |
18
// | GNU General Public License for more details.                                                         |
19
// |                                                                                                      |
20
// | You should have received a copy of the GNU General Public License                                    |
21
// | along with Foobar; if not, write to the Free Software                                                |
22
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
23
// +------------------------------------------------------------------------------------------------------+
954 florian 24
// CVS : $Id: adwi_wikini.fonct.php,v 1.9 2006-09-21 14:18:06 florian Exp $
434 ddelon 25
/**
26
* Contient les fonctions de l'application gestion des Wikini
27
*
28
*
29
*
30
*
31
*@package Admin_Wikini
32
*@subpackage Fonctions
33
//Auteur original :
34
*@author        David Delon <david.delon@tela-botanica.org>
35
//Autres auteurs :
36
*@author        Aucun
37
*@copyright     Tela-Botanica 2000-2004
954 florian 38
*@version       $Revision: 1.9 $
434 ddelon 39
// +------------------------------------------------------------------------------------------------------+
40
*/
41
 
42
// +------------------------------------------------------------------------------------------------------+
43
// |                                           LISTE de FONCTIONS                                         |
44
// +------------------------------------------------------------------------------------------------------+
45
 
46
/* CRUD */
47
 
48
/**
49
 *
50
 * D du CRUD
51
 * @return
52
 */
53
 
54
function adwi_supprimer_wikini($id_wikini, &$db) {
439 ddelon 55
 
56
// Suppression enregistrement
57
 
58
	$valeur = adwi_valeurs_par_defaut($id_wikini,$db );
59
 
434 ddelon 60
    $requete = "delete from gen_wikini where gewi_id_wikini =$id_wikini" ;
61
    $resultat = $db->query ($requete) ;
439 ddelon 62
 
63
// Suppression tables Wikini ...
436 ddelon 64
 
439 ddelon 65
    include_once ADWI_CHEMIN_BIBLIOTHEQUE.'gestion_wikini.class.php' ;
66
 
67
    $g_wikini = new gestion_wikini($db);
68
 
69
	if ((!isset($valeur['table_prefix'])) || (empty($config_wikini['$valeur'])))  {
70
		$valeur['table_prefix'] = $valeur['code_alpha_wikini'];
71
	}
72
 
73
 	$g_wikini->suppression_tables ($valeur['table_prefix']);
74
 
75
	if (GEN_FTP_UTILISE) {
76
	    /** Inclusion bibliothèque de PEAR gérant le FTP.*/
77
	    require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'Net/FTP.php';
78
 
79
	    // création de l'objet pear ftp
80
	    $objet_pear_ftp = new Net_FTP(PAP_FTP_SERVEUR, PAP_FTP_PORT);
81
	    // création de la connexion
82
	    $ftp_conn = $objet_pear_ftp->connect(PAP_FTP_SERVEUR, PAP_FTP_PORT);
83
	    // identification
84
	    $ftp_login_result = $objet_pear_ftp->login(PAP_FTP_UTILISATEUR, PAP_FTP_MOT_DE_PASSE);
85
 
86
	    // Gestion des erreurs ftp
87
	    if ((PEAR::isError($ftp_conn) || PEAR::isError($ftp_login_result))) {
88
	        $message =  '<p class="pap_erreur"> ERREUR Papyrus admin : impossible de se connecter par ftp.<br />'.
89
	                    'Serveur : '. PAP_FTP_SERVEUR .'<br />'.
90
	                    'Utilisateur : '. PAP_FTP_UTILISATEUR .'<br />'.
91
	                    'Erreur connexion : '.$ftp_conn->getMessage().'<br />'.
92
	                    'Erreur login : '.$ftp_login_result->getMessage().'<br />'.
93
	                    'Ligne n° : '. __LINE__ .'<br />'.
94
	                    'Fichier n° : '. __FILE__ .'<br /><p>';
95
	        print  $message;
96
	    }
97
 
98
	    $chemin_wikini = PAP_FTP_RACINE.ADWI_CHEMIN_WIKINI.$valeur['code_alpha_wikini'].GEN_SEP;
913 ddelon 99
 
100
	    if ($valeur['code_alpha_wikini']!='') {
439 ddelon 101
 
913 ddelon 102
		    $resultat = $objet_pear_ftp->rm($chemin_wikini, true);
103
 
104
		    if (PEAR::isError($resultat)) {
105
		        $message =  '<p class="pap_erreur"> ERREUR Papyrus admin : impossible de copier le wikini de reference par ftp.<br />'.
106
		                    'Wikini : '. $chemin_wikini .'<br />'.
107
		                    'Erreur origine : '. $resultat->getMessage() .'<br />'.
108
		                    'Ligne n° : '. __LINE__ .'<br />'.
109
		                    'Fichier n° : '. __FILE__ .'<br /></p>';
110
		            print $message;
111
		    }
112
	    }
439 ddelon 113
 
114
	}
115
 
116
// else {
117
 
118
// Gestion sans FTP à faire
119
 
120
	//}
121
 
122
 
123
 
434 ddelon 124
}
125
 
126
/**
127
 *
128
 *
129
 * @return
130
 */
131
 
436 ddelon 132
function adwi_valeurs_par_code_alpha($code_alpha_wikini, &$db) {
133
 
134
	$requete = "select * from gen_wikini where gewi_code_alpha_wikini='". $code_alpha_wikini."'" ;
135
    $resultat = $db->query ($requete) ;
136
 	if (DB::isError ($resultat)) {
137
        $GLOBALS['_GEN_commun']['debogage_erreur']->gererErreur(E_USER_WARNING, "Echec de la requete : $requete<br />".$resultat->getMessage(),
138
                                                                        __FILE__, __LINE__, 'admin_wikini')   ;
139
        return ;
140
    }
141
 
142
 
143
	$ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
144
	$resultat->free();
145
	unset ($requete, $resultat);
146
	return adwi_valeurs_par_defaut($ligne->gewi_id_wikini,$db);
439 ddelon 147
 
436 ddelon 148
}
149
 
150
 
434 ddelon 151
function adwi_valeurs_par_defaut($id_wikini, &$db) {
439 ddelon 152
 
434 ddelon 153
 
154
    // requete sur gen_wikin
155
 
156
    $requete = "select * from gen_wikini where gewi_id_wikini=$id_wikini" ;
157
    $resultat = $db->query ($requete) ;
158
    if (DB::isError ($resultat)) {
159
        trigger_error("Echec de la requete : $requete<br />".$resultat->getMessage(), E_USER_WARNING) ;
160
        return ;
161
    }
162
    $tableau_retour = array () ;
163
    $ligne = $resultat->fetchRow (DB_FETCHMODE_OBJECT) ;
164
 
165
    $tableau_retour['code_alpha_wikini'] = $ligne->gewi_code_alpha_wikini;
166
    $tableau_retour['bdd_hote'] = $ligne->gewi_bdd_hote ;
167
    $tableau_retour['bdd_nom'] = $ligne->gewi_bdd_nom;
168
    $tableau_retour['bdd_utilisateur'] = $ligne->gewi_bdd_utilisateur;
169
    $tableau_retour['bdd_mdp'] = $ligne->gewi_bdd_mdp;
170
    $tableau_retour['table_prefix'] = $ligne->gewi_table_prefix ;
171
    $tableau_retour['page'] = $ligne->gewi_page;
437 ddelon 172
    $tableau_retour['chemin'] = $ligne->gewi_chemin ;
434 ddelon 173
 
174
    unset ($requete, $resultat);
175
    return $tableau_retour ;
176
}
177
 
178
/**
179
 *
180
 * C du CRUD
857 florian 181
 * @return int id_wikini_bdd
434 ddelon 182
 */
183
 
184
 
185
function insertion ($valeur, &$db) {
186
 
187
	// Calcul dernier identifiant
188
    $id_wikini_bdd = SQL_obtenirNouveauId ($db, 'gen_wikini', 'gewi_id_wikini') ;
189
    $requete = "insert into gen_wikini set gewi_id_wikini ="
190
                .$id_wikini_bdd.","
436 ddelon 191
                .requete_wikini($valeur) ;
434 ddelon 192
    $resultat = $db->query ($requete) ;
193
    if (DB::isError ($resultat)) {
194
        trigger_error("Echec de la requete : $requete<br />".$resultat->getMessage(),E_USER_WARNING) ;
195
    }
439 ddelon 196
 
197
	if (GEN_FTP_UTILISE) {
198
	    /** Inclusion bibliothèque de PEAR gérant le FTP.*/
199
	    require_once ADWI_CHEMIN_BIBLIOTHEQUE_PEAR.'Net/FTP.php';
200
 
201
	    // création de l'objet pear ftp
202
	    $objet_pear_ftp = new Net_FTP(PAP_FTP_SERVEUR, PAP_FTP_PORT);
203
	    // création de la connexion
204
	    $ftp_conn = $objet_pear_ftp->connect(PAP_FTP_SERVEUR, PAP_FTP_PORT);
205
	    // identification
206
	    $ftp_login_result = $objet_pear_ftp->login(PAP_FTP_UTILISATEUR, PAP_FTP_MOT_DE_PASSE);
207
 
208
	    // Gestion des erreurs ftp
209
	    if ((PEAR::isError($ftp_conn) || PEAR::isError($ftp_login_result))) {
210
	        $message =  '<p class="pap_erreur"> ERREUR Papyrus admin : impossible de se connecter par ftp.<br />'.
211
	                    'Serveur : '. PAP_FTP_SERVEUR .'<br />'.
212
	                    'Utilisateur : '. PAP_FTP_UTILISATEUR .'<br />'.
213
	                    'Erreur connexion : '.$ftp_conn->getMessage().'<br />'.
214
	                    'Erreur login : '.$ftp_login_result->getMessage().'<br />'.
215
	                    'Ligne n° : '. __LINE__ .'<br />'.
216
	                    'Fichier n° : '. __FILE__ .'<br /><p>';
217
	        print  $message;
218
	    }
219
	    $objet_pear_ftp->mkdir(PAP_FTP_RACINE.ADWI_CHEMIN_WIKINI.$valeur['code_alpha_wikini']) ;
220
 
221
	    $chemin_wikini_bibliotheque = ADWI_CHEMIN_BIBLIOTHEQUE_WIKINI;
222
	    $chemin_wikini = PAP_FTP_RACINE.ADWI_CHEMIN_WIKINI.$valeur['code_alpha_wikini'].GEN_SEP;
223
 
481 ddelon 224
	    // Overwrite = fale (3eme parametre)
439 ddelon 225
	    $resultat = $objet_pear_ftp->putRecursive($chemin_wikini_bibliotheque, $chemin_wikini, false, FTP_BINARY);
226
 
227
	    if (PEAR::isError($resultat)) {
228
	        $message =  '<p class="pap_erreur"> ERREUR Papyrus admin : impossible de copier le wikini de reference par ftp.<br />'.
229
	                    'Fichier origine : '. $chemin_wikini_bibliotheque .'<br />'.
230
	                    'Fichier copié : '. $chemin_wikini .'<br />'.
231
	                    'Erreur origine : '. $resultat->getMessage() .'<br />'.
232
	                    'Ligne n° : '. __LINE__ .'<br />'.
233
	                    'Fichier n° : '. __FILE__ .'<br /></p>';
234
	            print $message;
235
	    }
236
	}
237
 
238
	// else {
239
 
240
	// Gestion sans FTP à faire
241
 
242
		//}
243
 
244
    // Creation tables wikini
245
 
246
    include_once ADWI_CHEMIN_BIBLIOTHEQUE.'gestion_wikini.class.php' ;
954 florian 247
 
439 ddelon 248
    $g_wikini = new gestion_wikini($db);
249
 
250
 
251
	if ((!isset($valeur['table_prefix'])) || (empty($config_wikini['$valeur'])))  {
252
		$valeur['table_prefix'] = $valeur['code_alpha_wikini'];
253
	}
954 florian 254
    $g_wikini->creation_tables($valeur['table_prefix']);
439 ddelon 255
 
256
 	// Creation Wakka.config.php
257
 
258
 	$config_wikini = adwi_config_wikini($valeur['code_alpha_wikini'] ,$db );
259
 
260
 
261
	$base_url=parse_url(PAP_URL);
262
	$dirname_base_url=dirname($base_url['path']);
263
	$config_base_url=$dirname_base_url.GEN_SEP.ADWI_CHEMIN_WIKINI.GEN_SEP.$config_wikini['code_alpha_wikini'].GEN_SEP."wakka.php?wiki=";
264
	$config_base_url = str_replace("//", "/", $config_base_url);
265
 
266
 
267
	$config = array(
268
    "wakka_version" => "0.1.1",
269
	"wikini_version" => "0.4.3",
270
    'mysql_host'            => $config_wikini['bdd_hote'],
271
    'mysql_database'        => $config_wikini['bdd_nom'],
272
    'mysql_user'            => $config_wikini['bdd_utilisateur'],
273
    'mysql_password'        => $config_wikini['bdd_mdp'],
274
    'table_prefix'          => $config_wikini['table_prefix'],
275
    'root_page'             => $config_wikini['page'],
276
    'wakka_name'            => $config_wikini['code_alpha_wikini'],
277
    'base_url'              => $config_base_url,
278
    'rewrite_mode'          => '0',
279
    'meta_keywords'         => '',
280
    'meta_description'      => '',
281
    'action_path'           => 'actions',
282
    'handler_path'          => 'handlers',
283
    'header_action'         => 'header',
284
    'footer_action'         => 'footer',
285
    'navigation_links'      => 'DerniersChangements :: DerniersCommentaires :: ParametresUtilisateur',
286
    'referrers_purge_time'  => 24,
287
    'pages_purge_time'      => 90,
288
    'default_write_acl'     => '*',
289
    'default_read_acl'      => '*',
290
    'default_comment_acl'   => '*',
291
    'preview_before_save'   => '0');
292
 
293
 
294
 
295
	// convert config array into PHP code
296
	$configCode = "<?php\n// wakka.config.php cr&eacute;&eacute;e ".strftime("%c")."\n// ne changez pas la wikini_version manuellement!\n\n\$wakkaConfig = array(\n";
297
	foreach ($config as $k => $v)
298
	{
299
		$entries[] = "\t\"".$k."\" => \"".$v."\"";
300
	}
301
	$configCode .= implode(",\n", $entries).");\n?>";
302
 
303
 
304
	$tempfn = tempnam("","");
305
	$temp = fopen($tempfn, "w");
306
 
307
	fwrite($temp, $configCode);
308
	fclose($temp);
309
 
310
 
311
	$fichier_config_source = $tempfn;
312
    $fichier_config_cible = PAP_FTP_RACINE.ADWI_CHEMIN_WIKINI.$valeur['code_alpha_wikini'].GEN_SEP."wakka.config.php";
313
 
314
    $resultat = $objet_pear_ftp->put($fichier_config_source, $fichier_config_cible, false, FTP_BINARY);
315
 
316
    if (PEAR::isError($resultat)) {
317
        $message =  '<p class="pap_erreur"> ERREUR Papyrus admin : impossible de copier le wikini de reference par ftp.<br />'.
832 florian 318
                    'Fichier origine : '. $chemin_wikini_bibliotheque .'<br />'.
439 ddelon 319
                    'Fichier copié : '. $chemin_wikini .'<br />'.
320
                    'Erreur origine : '. $resultat->getMessage() .'<br />'.
321
                    'Ligne n° : '. __LINE__ .'<br />'.
322
                    'Fichier n° : '. __FILE__ .'<br /></p>';
323
            print $message;
324
    }
325
 
326
	$objet_pear_ftp->disconnect();
327
 
328
	unlink($tempfn);
329
 
434 ddelon 330
}
331
 
332
/**
333
 *
334
 * U du CRUD
335
 * @return
336
 */
337
 
338
 
339
function mise_a_jour ($valeur, &$db) {
436 ddelon 340
    $requete = "update gen_wikini set ".requete_wikini($valeur)
434 ddelon 341
                .' where gewi_id_wikini ='.$GLOBALS['id_wikini'] ;
342
    $resultat = $db->query ($requete) ;
343
    if (DB::isError ($resultat)) {
344
        trigger_error("Echec de la requete : $requete<br />".$resultat->getMessage(),E_USER_WARNING) ;
345
    }
346
}
347
 
348
/**
349
 *
350
 * Formate code sql pour insertion à partir des valeurs entrees dans le formulaire
351
 *
352
 * @return  string  un morceau de code SQL
353
 */
354
 
436 ddelon 355
function requete_wikini (&$valeur) {
434 ddelon 356
    return   'gewi_code_alpha_wikini ="'.$valeur['code_alpha_wikini'].'", '
357
            .'gewi_bdd_hote ="'.$valeur['bdd_hote'].'", '
358
            .'gewi_bdd_nom="'.$valeur['bdd_nom'].'", '
359
            .'gewi_bdd_utilisateur ="'.$valeur['bdd_utilisateur'].'", '
360
            .'gewi_bdd_mdp="'.$valeur['bdd_mdp'].'", '
361
            .'gewi_table_prefix="'.$valeur['table_prefix'].'", '
437 ddelon 362
            .'gewi_chemin="'.$valeur['chemin'].'", '
434 ddelon 363
            .'gewi_page="'.$valeur['page'].'"';
364
}
365
 
366
 
439 ddelon 367
function adwi_config_wikini($code_alpha_wikini,&$db) {
368
 
369
	$config_wikini = adwi_valeurs_par_code_alpha($code_alpha_wikini,$db );
370
 
371
	// Parametres de base de donnée de Papyrus par défaut
372
 
373
	if ((!isset($config_wikini['bdd_hote'])) || (empty($config_wikini['bdd_hote']))) {
374
	   $config_wikini['bdd_hote'] = PAP_BDD_SERVEUR;
375
	}
376
 
377
	if ((!isset($config_wikini['bdd_nom'])) || (empty($config_wikini['bdd_nom'])))  {
378
	   $config_wikini['bdd_nom'] = PAP_BDD_NOM;
379
	}
380
 
381
	if ((!isset($config_wikini['bdd_utilisateur'])) || (empty($config_wikini['bdd_utilisateur'])))  {
382
	   $config_wikini['bdd_utilisateur'] = PAP_BDD_UTILISATEUR;
383
	}
384
 
385
	if ((!isset($config_wikini['bdd_mdp'])) || (empty($config_wikini['bdd_mdp'])))  {
386
	   $config_wikini['bdd_mdp'] = PAP_BDD_MOT_DE_PASSE;
387
	}
388
 
389
	if ((!isset($config_wikini['table_prefix'])) || (empty($config_wikini['table_prefix'])))  {
390
		$config_wikini['table_prefix'] = $code_alpha_wikini.'_';
391
	}
392
 
393
 
394
	// Ordre de selection de la page de demarrage :
395
 
396
	// Page par defaut du Wiki enregistré
397
	// PagePrincipale
398
 
399
	if ((!isset($config_wikini['page']))  || (empty($config_wikini['page']))) {
400
	   	$config_wikini['page'] = 'PagePrincipale';
401
	}
402
 
403
 
404
	/** Constante stockant le chemin du dossier contenant le site Wikini en cours */
405
 
406
	if ((!isset($config_wikini['chemin'])) || (empty($config_wikini['chemin'])))  {
407
		$config_wikini['chemin'] = GEN_CHEMIN_WIKINI.$config_wikini['code_alpha_wikini'].GEN_SEP;
408
	}
409
 
410
 
411
	return $config_wikini;
412
}
413
 
434 ddelon 414
// +------------------------------------------------------------------------------------------------------+
415
// |                                            PIED du PROGRAMME                                         |
416
// +------------------------------------------------------------------------------------------------------+
417
 
418
 
419
/* +--Fin du code ----------------------------------------------------------------------------------------+
420
*
421
* $Log: not supported by cvs2svn $
954 florian 422
* Revision 1.8  2006/07/19 13:55:01  ddelon
423
* Bug suppression de Wiki
424
*
913 ddelon 425
* Revision 1.7  2006/06/02 09:12:16  florian
426
* ajout constante chemin
427
*
857 florian 428
* Revision 1.6  2006/04/28 12:41:26  florian
429
* corrections erreurs chemin
430
*
832 florian 431
* Revision 1.5  2005/09/28 16:29:39  ddelon
432
* Merge modification projet
433
*
481 ddelon 434
* Revision 1.4  2005/09/09 09:37:17  ddelon
435
* Integrateur Wikini et administration des Wikini
436
*
439 ddelon 437
* Revision 1.3  2005/09/02 11:29:25  ddelon
438
* Integrateur Wikini et administration des Wikini
439
*
437 ddelon 440
* Revision 1.2  2005/08/31 17:34:52  ddelon
441
* Integrateur Wikini et administration des Wikini
442
*
436 ddelon 443
* Revision 1.1  2005/08/25 08:59:12  ddelon
444
* Integrateur Wikini et administration des Wikini
445
*
434 ddelon 446
* Revision 1.1  2005/03/09 10:44:04  jpm
447
* Mise au norme du nom du fichier.
448
*
449
* Revision 1.2  2005/03/09 10:40:33  alex
450
* version initiale
451
*
452
* Revision 1.1  2004/12/13 18:07:28  alex
453
* version initiale
454
*
455
*
456
* +-- Fin du code ----------------------------------------------------------------------------------------+
457
*/
458
?>