Subversion Repositories Applications.papyrus

Rev

Rev 25 | Go to most recent revision | Details | 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
*
37
*@package Administrateur de Sites
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
44
*@version       $Revision: 1.1 $ $Date: 2004-06-16 14:20:39 $
45
// +------------------------------------------------------------------------------------------------------+
46
//
47
// $Id: admin_site.php,v 1.1 2004-06-16 14:20:39 jpm Exp $
48
// FICHIER : $RCSfile: admin_site.php,v $
49
// AUTEUR  : $Author: jpm $
50
// VERSION : $Revision: 1.1 $
51
// DATE    : $Date: 2004-06-16 14:20:39 $
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
 
74
/** <BR> Inclusion de la bibliothèque de fonctions concernant les tables "gen_menu..." de Papyrus.
75
* Permet d'inclure la fonction d'affichage du "Vous êtes ici".*/
76
require_once ADSI_CHEMIN_BIBLIOTHEQUE_GEN.'pap_menu.fonct.php';
77
 
78
/** Inclusion de la bibliotheque de fonctions gérant les administrateur de Papyrus.*/
79
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_admin.fonct.php';
80
 
81
/** Inclusion de la bibliotheque de fonction gérant l'affichage de l'application Administrateur.*/
82
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_affichage.fonct.php';
83
 
84
/** Inclusion de la bibliotheque de fonction gérant l'administration du cache de Papyrus.*/
85
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_cache.fonct.php';
86
 
87
/** Inclusion de la bibliotheque de fonction gérant l'administration des sites de Papyrus.*/
88
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_site.fonct.php';
89
 
90
/** Inclusion de la bibliotheque de fonction gérant l'administration des squelettes des sites de Papyrus.*/
91
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_squelette.fonct.php';
92
 
93
/** Inclusion de la bibliotheque de fonction gérant l'administration des feuilles de styles des sites de Papyrus.*/
94
require_once ADSI_CHEMIN_BIBLIOTHEQUE_ADSI.'adsi_style.fonct.php';
95
 
96
// +------------------------------------------------------------------------------------------------------+
97
// |                                            CORPS du PROGRAMME                                        |
98
// +------------------------------------------------------------------------------------------------------+
99
/** Fonction afficherContenuTete() - Fonction appelé par le gestionnaire Papyrus.
100
*
101
* Elle retourne l'entête de l'application..
102
*
103
* @return  string  du code XHTML correspondant à la zone d'entête de l'application.
104
*/
105
function afficherContenuTete()
106
{
107
    return '';
108
}
109
 
110
/** Fonction afficherContenuCorps() - Retourne le contenu XHTML à afficherdans la zone contenu corps.
111
*
112
* Cette fonction retourne le contenu final d'un appel à l'application Administrateur.
113
* Cette fonction peut être appelé par Papyrus où depuis n'importe quel autre interface.
114
*
115
* @return  string  le contenu xhtml généré par l'application Administrateur et devant être affiché.
116
*/
117
function afficherContenuCorps()
118
{
119
    // Initialisation des variables. A faire migrer dans le fichier de configuration!!!
120
    // Globals variables from auth.php:
121
    //
122
    //  $project        : current project
123
    //  $locale         : current locale
124
    //  $db             : database name
125
    //  $link           : link to database
126
    //  $DOCrow         : current document
127
    //  $CURRENTPAGErow : current page
128
    //  $annuName       : name of the current annu
129
    //  $userid         : id of the current user
130
 
131
    // +----------------------------------------------------------------------------------------------+
132
    // Initialisation variables globales de Papyrus
133
    global $db, $_GEN_commun;
134
    // +----------------------------------------------------------------------------------------------+
135
    // Objet Pear Auth
136
    $objet_pear_auth = $_GEN_commun['pear_auth'];
137
    // +----------------------------------------------------------------------------------------------+
138
    // Gestion de l'URL pour revenir sur le menu courant.
139
    $url = $_GEN_commun['url']->getUrl();
140
    // +----------------------------------------------------------------------------------------------+
141
    // Gestion de la langue de l'interface.
142
    $id_langue = $_GEN_commun['url_i18n'];
143
    // +----------------------------------------------------------------------------------------------+
144
    // Arguments d'appel de cette application par un menu de Papyrus
145
    $application_arguments = $_GEN_commun['info_menu']->gm_application_arguments;
146
 
147
    if ($objet_pear_auth->getAuth()) {
148
        // +----------------------------------------------------------------------------------------------+
149
        // Initialisation des variables.
150
        $sortie_xhtml = '';// Le XHTML à renvoyer.// Ancien nom : $outputText
151
        $msg = '';
152
 
153
        // +----------------------------------------------------------------------------------------------+
154
        // Arguments passé par le menu de Génésia à l'application l'Administrateur???
155
 
156
        // Récupération des arguments
157
        $tab_arguments = explode(' ', $application_arguments);
158
 
159
        // Initialisation des variables qui contiendront les arguments
160
        $id_site_a_administrer  = '';
161
        $bool_site              = false;
162
        $bool_auth              = false;
163
        $bool_cache             = false;
164
        $bool_squelette         = false;
165
        $bool_style             = false;
166
 
167
        // Instantciation des variables arguments
168
        for ($i = 0; $i < count($tab_arguments); $i++) {
169
            $argument = explode('=', $tab_arguments[$i]);
170
 
171
            if ($argument[0] == 'id_site') {
172
                $id_site_a_administrer = $argument[1];
173
            }
174
 
175
            if ($argument[0] == 'bool_site') {
176
                // Interface d'administration des sites
177
                $bool_site = ($argument[1] == 'true');
178
            }
179
 
180
            if ($argument[0] == 'bool_auth') {
181
                // Interface d'administration du cache d'un site
182
                $bool_cache = ($argument[1] == 'true');
183
            }
184
 
185
            if ($argument[0] == 'bool_cache') {
186
                // Interface d'administration du cache d'un site
187
                $bool_cache = ($argument[1] == 'true');
188
            }
189
 
190
            if ($argument[0] == 'bool_squelette') {
191
                // Interface d'administration du fichier squelette d'un site
192
                $bool_squelette = ($argument[1] == 'true');
193
            }
194
 
195
            if ($argument[0] == 'bool_style') {
196
                // Interface d'administration du fichier de styles d'un site
197
                $bool_style = ($argument[1] == 'true');
198
            }
199
        }
200
 
201
        // Si aucun argument transmis on affiche l'interface de gestion des sites
202
        if ( !($bool_site && $bool_cache && $bool_squelette && $bool_style) ) {
203
            $bool_site = true;
204
        }
205
 
206
        // +----------------------------------------------------------------------------------------------+
207
        // Gestion des sites...
208
        if ($bool_site) {
209
            if (isset($_POST['form_sites_ajouter'])) {
210
                // Nous voulons le formulaire d'ajout d'un site
211
                $sortie_xhtml .= ADMIN_afficherFormSite($db, $url);
212
                return $sortie_xhtml;
213
            } else if (isset($_POST['site_enregistrer'])) {
214
                // Nous cherchons à enregistrer un site
215
                $message = ADMIN_validerFormSite($db, $_POST);
216
                if (!empty($message)) {
217
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
218
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
219
                } else {
220
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
221
                    $message = ADMIN_enregistrerSite($db, $_POST, $objet_pear_auth->getAuthData('ga_id_administrateur'));
222
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
223
                }
224
                return $sortie_xhtml;
225
            } else if (isset($_POST['form_sites_modifier'])) {
226
                // Nous cherchons à modifier un site
227
                $message = ADMIN_validerFormListesSites($db, $_POST);
228
                if (!empty($message)) {
229
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
230
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
231
                } else {
232
                    // Les données sont valide. Nous affichons le formulaire de modification.
233
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
234
                }
235
                return $sortie_xhtml;
236
            } else if (isset($_POST['site_modifier'])) {
237
                // Nous cherchons à enregistrer les modification d'un site
238
                $message = ADMIN_validerFormSite($db, $_POST);
239
                if (!empty($message)) {
240
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
241
                    $sortie_xhtml .= ADMIN_afficherFormSite($db, $url, $_POST, $message);
242
                } else {
243
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
244
                    $message = ADMIN_modifierSite($db, $_POST, $objet_pear_auth->getAuthData('ga_id_administrateur'));
245
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
246
                }
247
                return $sortie_xhtml;
248
            } else if (isset($_POST['form_sites_supprimer'])) {
249
                // Nous cherchons à supprimer un site
250
                $message = ADMIN_validerFormListesSites($db, $_POST);
251
                if (!empty($message)) {
252
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
253
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
254
                } else {
255
                    // Les données sont valide. Nous supprimons et retournons au formulaire de départ.
256
                    $message = ADMIN_supprimerSite($db, $_POST);
257
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
258
                }
259
                return $sortie_xhtml;
260
            } else if (isset($_POST['form_sites_traduire'])) {
261
                // Nous cherchons à modifier un site
262
                $message = ADMIN_validerFormListesSites($db, $_POST);
263
                if (!empty($message)) {
264
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
265
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
266
                } else {
267
                    // Les données sont valide. Nous supprimons et retournons au formulaire de départ.
268
                    $sortie_xhtml .= ADMIN_afficherFormTraduireSite($db, $url, $_POST, $message);
269
                }
270
                return $sortie_xhtml;
271
            } else if (isset($_POST['form_trad_site_enregistrer'])) {
272
                // Nous cherchons à enregistrer la traduction d'un site
273
                $message = ADMIN_validerFormTraduireSite($db, $_POST);
274
                if (!empty($message)) {
275
                    // Les données ne sont pas valide. Nous retournons le formulaires avec les messages d'erreurs.
276
                    $sortie_xhtml .= ADMIN_afficherFormModifierSite($db, $url, $message);
277
                } else {
278
                    // Les données sont valide. Nous les enregistrons et retournons au formulaire de départ.
279
                    $message = ADMIN_enregistrerFormModifierSite($db, $_POST);
280
                    $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url, $message);
281
                }
282
                return $sortie_xhtml;
283
            } else if (isset($_POST['form_annuler'])) {
284
                // Retour à la liste des sites
285
                $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url);
286
                return $sortie_xhtml;
287
            } else {
288
                // Liste des sites
289
                $sortie_xhtml .= ADMIN_afficherFormListeSites($db, $url);
290
            }
291
        }
292
        // +----------------------------------------------------------------------------------------------+
293
        // Gestion du cache... A FAIRE
294
        if ($bool_cache) {
295
 
296
            $msg = '';
297
 
298
            if ($guscmd == 'delcache') {
299
                delCache($db, $gusprjid);
300
            }
301
 
302
            // Defaut : nous listons tous les caches
303
            $sortie_xhtml .= listCaches($db, $id_site, $id_langue, $url, $msg);
304
 
305
            return $sortie_xhtml;
306
        }
307
        // +----------------------------------------------------------------------------------------------+
308
        // Gestion des squelettes... A FAIRE
309
        if ($bool_squelette) {
310
            switch ($guscmd) {
311
                case 'updpres':
312
                    $sortie_xhtml .= updatePresentation($db, $id_site, $id_langue, $url, $baseHidden, $gusprjid);
313
                    return $sortie_xhtml;
314
                    break;
315
                case 'commitupdpres' :
316
                    $sortie_xhtml .= commitUpdatePresentation($db, $id_site, $id_langue, $id_site_a_administrer, $url);
317
                    return $sortie_xhtml;
318
                    break;
319
            }
320
        }
321
        // +----------------------------------------------------------------------------------------------+
322
        // Gestion des styles... A FAIRE
323
        if ($bool_style) {
324
 
325
        }
326
 
327
        return $sortie_xhtml ;
328
    } else {
329
        // L'utilisateur n'est pas identifier, nous lui demandons de le faire.
330
        return GEN_afficherInfoIdentification();
331
    }
332
}//Fin de la fonction afficherContenuCorps().
333
 
334
/* +--Fin du code ---------------------------------------------------------------------------------------+
335
* $Log: not supported by cvs2svn $
336
* Revision 1.23  2004/05/10 12:23:26  jpm
337
* Correction mineure.
338
*
339
* Revision 1.22  2004/05/07 16:33:18  jpm
340
* Intégration de constantes.
341
*
342
* Revision 1.21  2004/05/07 07:23:03  jpm
343
* Ajout de la gestion des modification et suppression de site. Amélioration de la création des sites.
344
*
345
* Revision 1.20  2004/05/05 06:45:36  jpm
346
* Suppression de l'appel de la fonction générant le "vous êtes ici" dans la fonction affichant l'entête de l'application.
347
*
348
* Revision 1.19  2004/05/04 16:28:30  jpm
349
* Réduction de code pour la fonction afficherContenuTete().
350
*
351
* Revision 1.18  2004/04/30 16:22:59  jpm
352
* Poursuite de l'administration des sites.
353
*
354
* Revision 1.17  2004/04/22 08:33:11  jpm
355
* Transformation de $GS_GLOBAL en $_GEN_commun.
356
*
357
* Revision 1.16  2004/04/09 16:24:08  jpm
358
* Prise en compte des tables i18n.
359
*
360
* Revision 1.15  2004/04/02 16:37:09  jpm
361
* Modification de la gestion des actions d'administration.
362
* Ajout de commentaires.
363
*
364
* Revision 1.14  2004/03/31 16:58:15  jpm
365
* Changement des chemins d'accès aux fichiers à inclure.
366
*
367
* Revision 1.13  2004/03/24 10:07:04  jpm
368
* Ajout des commentaires d'entête.
369
* Début mise en conformité avec la convention de codage.
370
* Déplacement de la fonction d'affichage du xhtml dans la bibliothèque de fonctions.
371
*
372
* +--Fin du code ----------------------------------------------------------------------------------------+
373
*/
374
?>