Subversion Repositories Applications.papyrus

Rev

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

Rev Author Line No. Line
229 alex 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 library is free software; you can redistribute it and/or                                        |
9
// | modify it under the terms of the GNU Lesser 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
// | Lesser General Public License for more details.                                                      |
17
// |                                                                                                      |
18
// | You should have received a copy of the GNU Lesser 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
// +------------------------------------------------------------------------------------------------------+
1557 jp_milcent 22
// CVS : $Id: admin_application.php,v 1.9 2007-08-28 14:02:06 jp_milcent Exp $
229 alex 23
/**
24
* Application gérant les applications de Papyrus
25
*
302 jpm 26
* Cette application permet de gérer les applications de papyrus
229 alex 27
* elle permet de spécifier pour un monde quel annuaire utiliser
28
* et de gérer des authentifications de spip et ou wikini
29
*
30
*@package Admin_auth
31
//Auteur original :
32
*@author        Alexandre GRANIER <alexandre@tela-botanica.org>
33
*@copyright     Tela-Botanica 2000-2004
1557 jp_milcent 34
*@version       $Revision: 1.9 $
229 alex 35
// +------------------------------------------------------------------------------------------------------+
36
*/
37
 
38
// +------------------------------------------------------------------------------------------------------+
39
// |                                            ENTÊTE du PROGRAMME                                       |
40
// +------------------------------------------------------------------------------------------------------+
41
/** Inclusion du fichier de configuration de cette application.*/
42
require_once GEN_CHEMIN_PAP.'applications/admin_application/configuration/adap_configuration.inc.php';
43
 
44
//Utilisation de la bibliothèque PEAR NET_URL
45
 
46
/** Inclusion de la bibliothèque PEAR de conception de formulaire.*/
47
require_once ADAP_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm.php';
48
require_once ADAP_CHEMIN_BIBLIOTHEQUE_PEAR.'HTML/QuickForm/select.php';
49
 
50
/** Inclusion de l'API de fonctions gérant les erreurs sql.*/
276 jpm 51
require_once ADAP_CHEMIN_BIBLIOTHEQUE_API.'debogage/BOG_sql.fonct.php';
229 alex 52
 
53
/** Inclusion des fonctions de manipulation du sql.
54
* Permet la récupération d'un nouvel identifiant d'une table.*/
276 jpm 55
require_once ADAP_CHEMIN_BIBLIOTHEQUE_API.'sql/SQL_manipulation.fonct.php';
229 alex 56
 
57
require_once ADAP_CHEMIN_BIBLIOTHEQUE_API.'html/HTML_TableFragmenteur.php' ;
58
 
59
/** <BR> Inclusion de la bibliothèque de fonctions concernant les tables "gen_site..." de Papyrus.*/
60
require_once ADAP_CHEMIN_BIBLIOTHEQUE_GEN.'pap_site.fonct.php';
61
 
62
/** <BR> Inclusion de la bibliothèque de fonctions concernant les tables "gen_menu..." de Papyrus.*/
63
require_once ADAP_CHEMIN_BIBLIOTHEQUE_GEN.'pap_menu.fonct.php';
64
 
65
/** <BR> Inclusion de la bibliothèque de fonctions concernant les tables "gen_applications..." de Papyrus.*/
66
require_once ADAP_CHEMIN_BIBLIOTHEQUE_GEN.'pap_application.fonct.php';
67
 
68
/** <BR> Inclusion de la bibliothèque de fonctions concernant l'affichage commun.*/
302 jpm 69
require_once ADAP_CHEMIN_BIBLIOTHEQUE.'adap_application.fonct.php';
229 alex 70
 
71
require_once ADAP_CHEMIN_BIBLIOTHEQUE.'HTML_formulaireAppli.class.php' ;
72
 
73
 
74
// Inclusion des fichiers de traduction de l'appli ADME dePapyrus
75
if (file_exists(ADAP_CHEMIN_LANGUE.'adap_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php')) {
76
    /** Inclusion du fichier de traduction suite à la transaction avec le navigateur.*/
77
    require_once ADAP_CHEMIN_LANGUE.'adap_langue_'.$GLOBALS['_GEN_commun']['i18n'].'.inc.php';
78
} else {
79
    /** Inclusion du fichier de traduction par défaut.*/
80
    require_once ADAP_CHEMIN_LANGUE.'adap_langue_'.ADAP_I18N_DEFAUT.'.inc.php';
81
}
82
 
83
// Stockage des styles de l'application
84
GEN_stockerStyleExterne('adap_standard', ADAP_CHEMIN_STYLE.'adap_standard.css');
85
 
86
// +------------------------------------------------------------------------------------------------------+
87
// |                                            CORPS du PROGRAMME                                        |
88
// +------------------------------------------------------------------------------------------------------+
89
 
90
function afficherContenuCorps()
91
{
92
    $db = &$GLOBALS['_GEN_commun']['pear_db'] ;
93
    $url = $GLOBALS['_GEN_commun']['url'] ;
94
    $auth = &$GLOBALS['_GEN_commun']['pear_auth'] ;
1271 alexandre_ 95
 
1016 florian 96
    $res='';
229 alex 97
    if (!$auth->getAuth()) {
1016 florian 98
    	$res .= '<p class="zone_alert">'.ADAP_IDENTIFIEZ_VOUS.'</p>'."\n" ;
99
		$res .= '<form id="form_connexion" style="clear:both;" class="form_identification" action="' ;
100
		$res .= $url->getURL();
101
		$res .= '" method="post">
102
                <fieldset>
103
                    <legend>Identifiez vous</legend>
104
                        <label for="username">Courriel : </label>
2066 gduche 105
                        <input type="text"  id="username" name="username" maxlength="80" tabindex="10" value="courriel" />
1016 florian 106
                        <label for="password">Mot de passe : </label>
2066 gduche 107
                        <input type="password" id="password" name="password" maxlength="80" tabindex="20" value="mot de passe" />
108
                        <input type="submit" id="connexion" name="connexion" tabindex="30" value="ok" />
1016 florian 109
                </fieldset>
110
                </form>';
111
        return $res ;
112
    } else {
113
	    // Le lien pour une nouvelle entrée
1557 jp_milcent 114
	    $url->addQueryString('action', 'nouveau');
115
	    $url_nouveau = $url->getURL();
116
	    $url->removeQueryString('action', 'nouveau');
117
	    $res .= '<a href="'.$url_nouveau.'">'.ADAP_AJOUTER.'</a>'."\n<br />" ;
1016 florian 118
	    // traitement de la suppression
1271 alexandre_ 119
	    if (isset ($_REQUEST['action']) && $_REQUEST['action'] == 'supprimer') adap_supprimer_application($_REQUEST['id_appl'], $db) ;
1016 florian 120
 
121
	    // traitement de l'ajout
1271 alexandre_ 122
	    if (isset ($_REQUEST['action']) || isset ($_REQUEST['id_appl'])) {
1016 florian 123
	        $formulaire = new HTML_formulaireAppl('formulaire_appl', '', str_replace ('&amp;', '&', $url->getURL())) ;
124
	        $formulaire->construitFormulaire($url) ;
125
 
126
	        // On ajoute un champs caché avec action=nouveau_v
1271 alexandre_ 127
	        if (isset ($_REQUEST['action']) && $_REQUEST['action'] == 'nouveau') {
1016 florian 128
	            $formulaire->addElement ('hidden', 'action', 'nouveau_v') ;
129
	            return $formulaire->toHTML() ;
130
	        }
1271 alexandre_ 131
	        if (isset ($_REQUEST['id_appl']) && !isset ($_REQUEST['action'])) {
1016 florian 132
	            $formulaire->addElement ('hidden', 'action', 'modifier_v') ;
1271 alexandre_ 133
	            $formulaire->addElement ('hidden', 'id_appl', $_REQUEST['id_appl']) ;
134
	            $formulaire->setDefaults(adap_valeurs_par_defaut($_REQUEST['id_appl'], $db)) ;
1016 florian 135
	            return $formulaire->toHTML() ;
136
	        }
1271 alexandre_ 137
	        if ($_REQUEST['action'] == 'modifier_v') {
1016 florian 138
	            if ($formulaire->validate()) {
139
	                mise_a_jour ($formulaire->getSubmitValues(), $db) ;
140
	            }
141
	        }
1271 alexandre_ 142
	        if ($_REQUEST['action'] == 'nouveau_v') {
1016 florian 143
	            if ($formulaire->validate()) {
144
	                insertion ($formulaire->getSubmitValues(), $db) ;
145
	            }
146
	        }
147
 
148
	    }
149
	    // Comportement par défaut
150
	    // requete sur la table gen_application
1076 alexandre_ 151
	    $requete = 'SELECT gap_id_application, gap_nom FROM gen_application where gap_id_application <> 0 ORDER BY gap_nom ASC' ;
1016 florian 152
 
153
	    $resultat = $db->query ($requete) ;
154
	    if (DB::isError ($resultat)) {
155
	        $GLOBALS['_GEN_commun']['debogage_erreur']->gererErreur(E_USER_WARNING, "Echec de la requete : $requete<br />".$resultat->getMessage(),
156
	                                                                        __FILE__, __LINE__, 'admin_appl')   ;
157
	        return ;
158
	    }
159
	    $liste = new HTML_TableFragmenteur () ;
160
	    $liste->construireEntete(array (ADAP_NOM_APPL, ADAP_SUPPRIMER)) ;
161
	    $tableau_appl = array() ;
162
	    while ($ligne = $resultat->fetchRow()) {
163
	        $url->addQueryString ('id_appl', $ligne[0]) ;
164
	        array_push ($tableau_appl, array ('<a href="'.$url->getURL().'">'.$ligne[1].'</a>'."\n",    // Première colonne, le nom de l'application
165
	                                            '<a href="'.$url->getURL().'&amp;action=supprimer" onclick="javascript:return confirm (\''.ADAP_SUPPRIMER.' ?\');">'.ADAP_SUPPRIMER.'</a>'."\n"
166
	                                            ));
167
	    }
168
	    $liste->construireListe($tableau_appl) ;
169
	    $res .= $liste->toHTML();
170
	    return $res ;
229 alex 171
    }
172
}// Fin de la fonction afficherContenuCorps()
173
 
174
// +------------------------------------------------------------------------------------------------------+
175
// |                                            PIED du PROGRAMME                                         |
176
// +------------------------------------------------------------------------------------------------------+
177
 
178
 
179
 
180
/* +--Fin du code ----------------------------------------------------------------------------------------+
181
*
182
* $Log: not supported by cvs2svn $
1557 jp_milcent 183
* Revision 1.8  2007-03-20 14:17:36  alexandre_tb
184
* remplacement des varaibles $GLOBALS par $_REQUEST, pour que l appli fonctionne avec les register_globals à Off
185
*
1271 alexandre_ 186
* Revision 1.7  2006/12/01 10:39:14  alexandre_tb
187
* Suppression des références aux applettes
188
*
1076 alexandre_ 189
* Revision 1.6  2006/10/06 10:40:51  florian
190
* harmonisation des messages d'erreur de l'authentification
191
*
1016 florian 192
* Revision 1.5  2006/09/07 13:28:39  jp_milcent
193
* Mise en majuscule des termes SQL et trie des application par ordre alphabétique.
194
*
923 jp_milcent 195
* Revision 1.4  2005/03/09 10:46:17  jpm
196
* Changement d'un nom de fichier.
197
*
302 jpm 198
* Revision 1.3  2005/03/09 10:40:26  alex
199
* version initiale
200
*
300 alex 201
* Revision 1.2  2005/02/28 10:32:59  jpm
202
* Changement de nom de dossier.
203
*
276 jpm 204
* Revision 1.1  2004/12/13 18:07:19  alex
205
* version initiale
229 alex 206
*
276 jpm 207
*
229 alex 208
* +-- Fin du code ----------------------------------------------------------------------------------------+
209
*/
210
?>