Subversion Repositories Applications.papyrus

Rev

Rev 25 | Rev 205 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
6 jpm 1
<?php
2
/*vim: set expandtab tabstop=4 shiftwidth=4: */
3
// +------------------------------------------------------------------------------------------------------+
4
// | PHP version 4.1                                                                                      |
5
// +------------------------------------------------------------------------------------------------------+
6
// | Copyright (C) 2001 Laurent COUDOUNEAU (lc@gsite.org)                                                 |
7
// | Copyright (C) 2004 Tela Botanica (accueil@tela-botanica.org)                                         |
8
// +------------------------------------------------------------------------------------------------------+
9
// | This library is free software; you can redistribute it and/or                                        |
10
// | modify it under the terms of the GNU Lesser General Public                                           |
11
// | License as published by the Free Software Foundation; either                                         |
12
// | version 2.1 of the License, or (at your option) any later version.                                   |
13
// |                                                                                                      |
14
// | This library is distributed in the hope that it will be useful,                                      |
15
// | but WITHOUT ANY WARRANTY; without even the implied warranty of                                       |
16
// | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU                                    |
17
// | Lesser General Public License for more details.                                                      |
18
// |                                                                                                      |
19
// | You should have received a copy of the GNU Lesser General Public                                     |
20
// | License along with this library; if not, write to the Free Software                                  |
21
// | Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA                            |
22
// +------------------------------------------------------------------------------------------------------+
23
/**
24
* Application Administrateur de Papyrus.
25
*
26
* Application permettant de gérer actulement les projets et la mise en cache des pages.
27
* Dans l'avenir la gestion via l'interface d'administration des fichiers CSS et
28
* des Squelettes pourrait être envisagée.
29
* Cette application peut prendre 1 des 3 arguments ci-dessous lors de son appel par un menu de Papyrus :
30
* - site : pour indiquer que l'on veut gérer les sites
31
* - cache : pour indiquer que l'on veut gérer le cache
32
* Liste des paquetages Pear nécessaire à cette application :
33
* - DB
34
* - Auth
35
* - Net_URL
36
*
25 jpm 37
*@package Admin_site
6 jpm 38
//Auteur original :
39
*@author        Laurent COUDOUNEAU <lc@gsite.org>
40
//Autres auteurs :
41
*@author        Alexandre GRANIER <alexandre@tela-botanica.org>
42
*@author        Jean-Pascal MILCENT <jpm@tela-botanica.org>
43
*@copyright     Tela-Botanica 2000-2004
72 jpm 44
*@version       $Revision: 1.3 $ $Date: 2004-10-18 18:27:37 $
6 jpm 45
// +------------------------------------------------------------------------------------------------------+
46
//
72 jpm 47
// $Id: admin_site.php,v 1.3 2004-10-18 18:27:37 jpm Exp $
6 jpm 48
// FICHIER : $RCSfile: admin_site.php,v $
49
// AUTEUR  : $Author: jpm $
72 jpm 50
// VERSION : $Revision: 1.3 $
51
// DATE    : $Date: 2004-10-18 18:27:37 $
6 jpm 52
// +------------------------------------------------------------------------------------------------------+
53
**/
54
 
55
// +------------------------------------------------------------------------------------------------------+
56
// |                                            ENTÊTE du PROGRAMME                                       |
57
// +------------------------------------------------------------------------------------------------------+
58
 
59
// Note : cette application fait appel à des fonctions présentent dans la bibliotheque de Papyrus.
60
 
61
/** Inclusion du fichier de configuration de cette application.*/
62
require_once GEN_CHEMIN_APPLICATION.'admin_site/configuration/adsi_configuration.inc.php';
63
 
64
/** Inclusion de la bibliothèque PEAR de conception de formulaire.*/
65
require_once ADSI_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm.php';
66
 
67
/** Inclusion de l'API de fonctions gérant les erreurs sql.*/
68
require_once ADSI_CHEMIN_BIBLIOTHEQUE_API.'debogage_1.0/BOG_sql.fonct.php';
69
 
70
/** Inclusion des fonctions de manipulation du sql.
71
* Permet la récupération d'un nouvel identifiant d'une table.*/
72
require_once ADSI_CHEMIN_BIBLIOTHEQUE_API.'sql_1.0/SQL_manipulation.fonct.php';
73
 
72 jpm 74
/** Inclusion des fonctions de manipulation de fichiers et dossiers.
75
* Permet la suppression d'un dossier et de son contenu.*/
76
require_once ADSI_CHEMIN_BIBLIOTHEQUE_API.'fichier_1.0/FIC_manipulation.fonct.php';
77
 
6 jpm 78
/** <BR> Inclusion de la bibliothèque de fonctions concernant les tables "gen_menu..." de Papyrus.
79
* Permet d'inclure la fonction d'affichage du "Vous êtes ici".*/
80
require_once ADSI_CHEMIN_BIBLIOTHEQUE_GEN.'pap_menu.fonct.php';
81
 
82
/** Inclusion de la bibliotheque de fonctions gérant les administrateur de Papyrus.*/
83
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_admin.fonct.php';
84
 
85
/** Inclusion de la bibliotheque de fonction gérant l'affichage de l'application Administrateur.*/
86
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_affichage.fonct.php';
87
 
88
/** Inclusion de la bibliotheque de fonction gérant l'administration des sites de Papyrus.*/
89
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_site.fonct.php';
90
 
25 jpm 91
///** Inclusion de la bibliotheque de fonction gérant l'administration du cache de Papyrus.*/
92
//require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_cache.fonct.php';
6 jpm 93
 
25 jpm 94
///** Inclusion de la bibliotheque de fonction gérant l'administration des squelettes des sites de Papyrus.*/
95
//require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_squelette.fonct.php';
6 jpm 96
 
25 jpm 97
///** Inclusion de la bibliotheque de fonction gérant l'administration des feuilles de styles des sites de Papyrus.*/
98
//require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_style.fonct.php';
99
 
6 jpm 100
// +------------------------------------------------------------------------------------------------------+
101
// |                                            CORPS du PROGRAMME                                        |
102
// +------------------------------------------------------------------------------------------------------+
103
/** Fonction afficherContenuTete() - Fonction appelé par le gestionnaire Papyrus.
104
*
105
* Elle retourne l'entête de l'application..
106
*
107
* @return  string  du code XHTML correspondant à la zone d'entête de l'application.
108
*/
109
function afficherContenuTete()
110
{
111
    return '';
112
}
113
 
114
/** Fonction afficherContenuCorps() - Retourne le contenu XHTML à afficherdans la zone contenu corps.
115
*
116
* Cette fonction retourne le contenu final d'un appel à l'application Administrateur.
117
* Cette fonction peut être appelé par Papyrus où depuis n'importe quel autre interface.
118
*
119
* @return  string  le contenu xhtml généré par l'application Administrateur et devant être affiché.
120
*/
121
function afficherContenuCorps()
122
{
123
    // Initialisation des variables. A faire migrer dans le fichier de configuration!!!
124
    // Globals variables from auth.php:
125
    //
126
    //  $project        : current project
127
    //  $locale         : current locale
128
    //  $db             : database name
129
    //  $link           : link to database
130
    //  $DOCrow         : current document
131
    //  $CURRENTPAGErow : current page
132
    //  $annuName       : name of the current annu
133
    //  $userid         : id of the current user
134
 
135
    // +----------------------------------------------------------------------------------------------+
136
    // Initialisation variables globales de Papyrus
137
    global $db, $_GEN_commun;
138
    // +----------------------------------------------------------------------------------------------+
139
    // Objet Pear Auth
140
    $objet_pear_auth = $_GEN_commun['pear_auth'];
141
    // +----------------------------------------------------------------------------------------------+
142
    // Gestion de l'URL pour revenir sur le menu courant.
143
    $url = $_GEN_commun['url']->getUrl();
144
    // +----------------------------------------------------------------------------------------------+
145
    // Gestion de la langue de l'interface.
146
    $id_langue = $_GEN_commun['url_i18n'];
147
    // +----------------------------------------------------------------------------------------------+
148
    // Arguments d'appel de cette application par un menu de Papyrus
149
    $application_arguments = $_GEN_commun['info_menu']->gm_application_arguments;
150
 
151
    if ($objet_pear_auth->getAuth()) {
152
        // +----------------------------------------------------------------------------------------------+
153
        // Initialisation des variables.
154
        $sortie_xhtml = '';// Le XHTML à renvoyer.// Ancien nom : $outputText
155
        $msg = '';
156
 
157
        // +----------------------------------------------------------------------------------------------+
158
        // Arguments passé par le menu de Génésia à l'application l'Administrateur???
159
 
160
        // Récupération des arguments
161
        $tab_arguments = explode(' ', $application_arguments);
162
 
163
        // Initialisation des variables qui contiendront les arguments
164
        $id_site_a_administrer  = '';
165
        $bool_site              = false;
166
        $bool_auth              = false;
167
        $bool_cache             = false;
168
        $bool_squelette         = false;
169
        $bool_style             = false;
170
 
171
        // Instantciation des variables arguments
172
        for ($i = 0; $i < count($tab_arguments); $i++) {
173
            $argument = explode('=', $tab_arguments[$i]);
174
 
175
            if ($argument[0] == 'id_site') {
176
                $id_site_a_administrer = $argument[1];
177
            }
178
 
179
            if ($argument[0] == 'bool_site') {
180
                // Interface d'administration des sites
181
                $bool_site = ($argument[1] == 'true');
182
            }
183
 
184
            if ($argument[0] == 'bool_auth') {
185
                // Interface d'administration du cache d'un site
186
                $bool_cache = ($argument[1] == 'true');
187
            }
188
 
189
            if ($argument[0] == 'bool_cache') {
190
                // Interface d'administration du cache d'un site
191
                $bool_cache = ($argument[1] == 'true');
192
            }
193
 
194
            if ($argument[0] == 'bool_squelette') {
195
                // Interface d'administration du fichier squelette d'un site
196
                $bool_squelette = ($argument[1] == 'true');
197
            }
198
 
199
            if ($argument[0] == 'bool_style') {
200
                // Interface d'administration du fichier de styles d'un site
201
                $bool_style = ($argument[1] == 'true');
202
            }
203
        }
204
 
205
        // Si aucun argument transmis on affiche l'interface de gestion des sites
206
        if ( !($bool_site && $bool_cache && $bool_squelette && $bool_style) ) {
207
            $bool_site = true;
208
        }
209
 
210
        // +----------------------------------------------------------------------------------------------+
211
        // Gestion des sites...
212
        if ($bool_site) {
213
            if (isset($_POST['form_sites_ajouter'])) {
214
                // Nous voulons le formulaire d'ajout d'un site
215
                $sortie_xhtml .= ADMIN_afficherFormSite($db, $url);
216
                return $sortie_xhtml;
217
            } else if (isset($_POST['site_enregistrer'])) {
218
                // Nous cherchons à enregistrer un site
219
                $message = ADMIN_validerFormSite($db, $_POST);
220
                if (!empty($message)) {
221
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
222
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
223
                } else {
224
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
225
                    $message = ADMIN_enregistrerSite($db, $_POST, $objet_pear_auth->getAuthData('ga_id_administrateur'));
226
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
227
                }
228
                return $sortie_xhtml;
229
            } else if (isset($_POST['form_sites_modifier'])) {
230
                // Nous cherchons à modifier un site
231
                $message = ADMIN_validerFormListesSites($db, $_POST);
232
                if (!empty($message)) {
233
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
234
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
235
                } else {
236
                    // Les données sont valide. Nous affichons le formulaire de modification.
237
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
238
                }
239
                return $sortie_xhtml;
240
            } else if (isset($_POST['site_modifier'])) {
241
                // Nous cherchons à enregistrer les modification d'un site
242
                $message = ADMIN_validerFormSite($db, $_POST);
243
                if (!empty($message)) {
244
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
245
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
246
                } else {
247
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
248
                    $message = ADMIN_modifierSite($db, $_POST, $objet_pear_auth->getAuthData('ga_id_administrateur'));
249
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
250
                }
251
                return $sortie_xhtml;
252
            } else if (isset($_POST['form_sites_supprimer'])) {
253
                // Nous cherchons à supprimer un site
254
                $message = ADMIN_validerFormListesSites($db, $_POST);
255
                if (!empty($message)) {
256
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
257
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
258
                } else {
259
                    // Les données sont valide. Nous supprimons et retournons au formulaire de départ.
260
                    $message = ADMIN_supprimerSite($db, $_POST);
261
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
262
                }
263
                return $sortie_xhtml;
264
            } else if (isset($_POST['form_sites_traduire'])) {
265
                // Nous cherchons à modifier un site
266
                $message = ADMIN_validerFormListesSites($db, $_POST);
267
                if (!empty($message)) {
268
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
269
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
270
                } else {
271
                    // Les données sont valide. Nous supprimons et retournons au formulaire de départ.
272
                    $sortie_xhtml .= ADMIN_afficherFormTraduireSite($db, $url, $_POST, $message);
273
                }
274
                return $sortie_xhtml;
275
            } else if (isset($_POST['form_trad_site_enregistrer'])) {
276
                // Nous cherchons à enregistrer la traduction d'un site
277
                $message = ADMIN_validerFormTraduireSite($db, $_POST);
278
                if (!empty($message)) {
279
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
280
                    $sortie_xhtml .= ADMIN_afficherFormModifierSite($db, $url, $message);
281
                } else {
282
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
283
                    $message = ADMIN_enregistrerFormModifierSite($db, $_POST);
284
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
285
                }
286
                return $sortie_xhtml;
287
            } else if (isset($_POST['form_annuler'])) {
288
                // Retour à la liste des sites
289
                $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url);
290
                return $sortie_xhtml;
291
            } else {
292
                // Liste des sites
293
                $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url);
294
            }
295
        }
296
        // +----------------------------------------------------------------------------------------------+
297
        // Gestion du cache... A FAIRE
298
        if ($bool_cache) {
299
 
300
            $msg = '';
301
 
302
            if ($guscmd == 'delcache') {
303
                delCache($db, $gusprjid);
304
            }
305
 
306
            // Defaut : nous listons tous les caches
307
            $sortie_xhtml .= listCaches($db, $id_site, $id_langue, $url, $msg);
308
 
309
            return $sortie_xhtml;
310
        }
311
        // +----------------------------------------------------------------------------------------------+
312
        // Gestion des squelettes... A FAIRE
313
        if ($bool_squelette) {
314
            switch ($guscmd) {
315
                case 'updpres':
316
                    $sortie_xhtml .= updatePresentation($db, $id_site, $id_langue, $url, $baseHidden, $gusprjid);
317
                    return $sortie_xhtml;
318
                    break;
319
                case 'commitupdpres' :
320
                    $sortie_xhtml .= commitUpdatePresentation($db, $id_site, $id_langue, $id_site_a_administrer, $url);
321
                    return $sortie_xhtml;
322
                    break;
323
            }
324
        }
325
        // +----------------------------------------------------------------------------------------------+
326
        // Gestion des styles... A FAIRE
327
        if ($bool_style) {
328
 
329
        }
330
 
331
        return $sortie_xhtml ;
332
    } else {
333
        // L'utilisateur n'est pas identifier, nous lui demandons de le faire.
334
        return GEN_afficherInfoIdentification();
335
    }
336
}//Fin de la fonction afficherContenuCorps().
337
 
338
/* +--Fin du code ---------------------------------------------------------------------------------------+
339
* $Log: not supported by cvs2svn $
72 jpm 340
* Revision 1.2  2004/07/06 17:08:14  jpm
341
* Modification de la documentation pour une mailleur analyse par PhpDocumentor.
342
*
25 jpm 343
* Revision 1.1  2004/06/16 14:20:39  jpm
344
* Changement de nom de Génésia en Papyrus.
345
* Changement de l'arborescence.
346
*
6 jpm 347
* Revision 1.23  2004/05/10 12:23:26  jpm
348
* Correction mineure.
349
*
350
* Revision 1.22  2004/05/07 16:33:18  jpm
351
* Intégration de constantes.
352
*
353
* Revision 1.21  2004/05/07 07:23:03  jpm
354
* Ajout de la gestion des modification et suppression de site. Amélioration de la création des sites.
355
*
356
* Revision 1.20  2004/05/05 06:45:36  jpm
357
* Suppression de l'appel de la fonction générant le "vous êtes ici" dans la fonction affichant l'entête de l'application.
358
*
359
* Revision 1.19  2004/05/04 16:28:30  jpm
360
* Réduction de code pour la fonction afficherContenuTete().
361
*
362
* Revision 1.18  2004/04/30 16:22:59  jpm
363
* Poursuite de l'administration des sites.
364
*
365
* Revision 1.17  2004/04/22 08:33:11  jpm
366
* Transformation de $GS_GLOBAL en $_GEN_commun.
367
*
368
* Revision 1.16  2004/04/09 16:24:08  jpm
369
* Prise en compte des tables i18n.
370
*
371
* Revision 1.15  2004/04/02 16:37:09  jpm
372
* Modification de la gestion des actions d'administration.
373
* Ajout de commentaires.
374
*
375
* Revision 1.14  2004/03/31 16:58:15  jpm
376
* Changement des chemins d'accès aux fichiers à inclure.
377
*
378
* Revision 1.13  2004/03/24 10:07:04  jpm
379
* Ajout des commentaires d'entête.
380
* Début mise en conformité avec la convention de codage.
381
* Déplacement de la fonction d'affichage du xhtml dans la bibliothèque de fonctions.
382
*
383
* +--Fin du code ----------------------------------------------------------------------------------------+
384
*/
385
?>