[SPIP][PLUGINS] v3.0-->v3.2
[lhc/web/www.git] / www / plugins-dist / svp / formulaires / admin_plugin.php
1 <?php
2
3 /**
4 * Gestion du formulaire de gestion des plugins
5 *
6 * @plugin SVP pour SPIP
7 * @license GPL
8 * @package SPIP\SVP\Formulaires
9 */
10
11 if (!defined("_ECRIRE_INC_VERSION")) {
12 return;
13 }
14
15 /**
16 * Chargement du formulaire de gestion des plugins
17 *
18 * @uses svp_actualiser_paquets_locaux()
19 * @param string $voir
20 * Statut des plugins que l'on souhaite voir : actif, inactif, tous
21 * @param string $verrouille
22 * Types de plugins que l'on souhaite voir :
23 * - 'non' : les plugins utilisateurs
24 * - 'oui' : les plugins verrouillés (plugins-dist)
25 * - 'tous' : les deux !
26 * @param string|int $id_paquet
27 * Identifiant du paquet dont on veut obtenir une description complète
28 * lors de l'affichage du formulaire
29 * @param string $redirect
30 * URL de redirection après les traitements
31 * @return array
32 * Environnement du formulaire
33 **/
34 function formulaires_admin_plugin_charger_dist($voir = 'actif', $verrouille = 'non', $id_paquet = '', $redirect = '') {
35 $valeurs = array();
36
37 // actualiser la liste des paquets locaux systematiquement
38 include_spip('inc/svp_depoter_local');
39 // sans forcer tout le recalcul en base, mais en récupérant les erreurs XML
40 $valeurs['_erreurs_xml'] = array();
41 svp_actualiser_paquets_locaux(false, $valeurs['_erreurs_xml']);
42
43 $valeurs['actif'] = 'oui';
44 if ($voir == 'inactif') {
45 $valeurs['actif'] = 'non';
46 }
47 if ($voir == 'tous') {
48 $valeurs['actif'] = '';
49 }
50
51 $valeurs['constante'] = array('_DIR_PLUGINS', '_DIR_PLUGINS_SUPPL');
52 if ($verrouille == 'oui') {
53 $valeurs['constante'] = array('_DIR_PLUGINS_DIST');
54 }
55 if ($verrouille == 'tous') {
56 $valeurs['constante'] = array();
57 }
58
59 $valeurs['verrouille'] = $verrouille;
60 $valeurs['id_paquet'] = $id_paquet;
61 $valeurs['actions'] = array();
62 $valeurs['ids_paquet'] = _request('ids_paquet');
63 $valeurs['afficher_incompatibles'] = _request('afficher_incompatibles');
64 $valeurs['_todo'] = _request('_todo');
65 $valeurs['_notices'] = _request('_notices');
66 $valeurs['_libelles_actions'] = _request('_libelles_actions');
67
68 return $valeurs;
69 }
70
71 /**
72 * Vérifications du formulaire de gestion des plugins
73 *
74 * Appelle le décideur qui détermine la liste des actions à faire et si celles-ci
75 * peuvent être faites (dépendances connues). Une erreur sera levé dans le
76 * cas contraire.
77 *
78 * Si toutes les actions peuvent être faites, une demande de confirmation
79 * est envoyée (dans une erreur spéciale), présentant alors toutes les
80 * actions qui seront réalisées (celle demandée + celles à faire par voie
81 * de conséquence.
82 *
83 * Si on reçoit une demande de confirmation, on sort sans lever d'erreur !
84 *
85 * @uses svp_decider_verifier_actions_demandees()
86 *
87 * @param string $voir
88 * Statut des plugins que l'on souhaite voir : actif, inactif, tous
89 * @param string $verrouille
90 * Types de plugins que l'on souhaite voir :
91 * - 'non' : les plugins utilisateurs
92 * - 'oui' : les plugins verrouillés (plugins-dist)
93 * - 'tous' : les deux !
94 * @param string|int $id_paquet
95 * Identifiant du paquet dont on veut obtenir une description complète
96 * lors de l'affichage du formulaire
97 * @param string $redirect
98 * URL de redirection après les traitements
99 * @return array
100 * Tableau des erreurs
101 **/
102 function formulaires_admin_plugin_verifier_dist($voir = 'actif', $verrouille = 'non', $id_paquet = '', $redirect = '') {
103
104 $erreurs = array();
105
106 if (_request('annuler_actions')) {
107 // Requete : Annulation des actions d'installation en cours
108 // -- On vide la liste d'actions en cours
109 set_request('_todo', '');
110 // -- vider les paquets coches s'il y en a
111 set_request('ids_paquet', array());
112 } elseif (_request('valider_actions')) {
113 // ...
114 } else {
115 $a_actionner = array();
116
117 // actions globales...
118 if ($action_globale = _request('action_globale') and _request('appliquer')) {
119 $ids_paquet = _request('ids_paquet');
120 if (!is_array($ids_paquet)) {
121 $erreurs['message_erreur'] = _T('svp:message_erreur_aucun_plugin_selectionne');
122 } else {
123 foreach ($ids_paquet as $i) {
124 $a_actionner[$i] = $action_globale;
125 }
126 }
127 // action unitaire
128 } else {
129 $actions = _request('actions');
130 // $actions[type][id] = Texte
131 // -> $a_actionner[id] = type
132 foreach ($actions as $action => $p) {
133 foreach ($p as $i => $null) {
134 $a_actionner[$i] = $action;
135 }
136 }
137 }
138 // lancer les verifications
139 if (!$a_actionner) {
140 $erreurs['message_erreur'] = _T('svp:message_erreur_aucun_plugin_selectionne');
141 } else {
142
143 // On fait appel au decideur pour determiner la liste exacte des commandes apres
144 // verification des dependances
145 include_spip('inc/svp_decider');
146 svp_decider_verifier_actions_demandees($a_actionner, $erreurs);
147 $todo = _request('_todo') ? unserialize(_request('_todo')) : array();
148 $actions = _request('_decideur_actions') ? unserialize(_request('_decideur_actions')) : array();
149 // si c'est une action simple (hors suppression) sans rien a faire de plus que demande, on y go direct
150 if (in_array('stop', $todo) or in_array('kill', $todo)) {
151 if (in_array('stop', $todo)) {
152 $notices = array();
153 $notices['decideur_warning'] = _T('svp:confirmer_desinstaller');
154 set_request('_notices', $notices);
155 }
156 } elseif (
157 count($todo) == count($a_actionner) // et on n'a pas plus d'actions que ce qu'on avait demandé explicitement
158 and !isset($erreurs['decideur_erreurs'])
159 and (!isset($erreurs['decideur_propositions']) or !count($actions['decideur_propositions']))
160 ) {
161 set_request('valider_actions', true); // on fake la validation, non mais ho !
162 }
163 }
164 }
165
166 if (count($erreurs) and !isset($erreurs['message_erreur'])) {
167 $erreurs['message_erreur'] = '';
168 }
169
170 return $erreurs;
171 }
172
173 /**
174 * Traitement du formulaire de gestion des plugins
175 *
176 * Si une liste d'action est validée, on redirige de formulaire sur
177 * l'action 'actionner' qui les traitera une par une.
178 *
179 * @uses svp_actionner_traiter_actions_demandees()
180 *
181 * @param string $voir
182 * Statut des plugins que l'on souhaite voir : actif, inactif, tous
183 * @param string $verrouille
184 * Types de plugins que l'on souhaite voir :
185 * - 'non' : les plugins utilisateurs
186 * - 'oui' : les plugins verrouillés (plugins-dist)
187 * - 'tous' : les deux !
188 * @param string|int $id_paquet
189 * Identifiant du paquet dont on veut obtenir une description complète
190 * lors de l'affichage du formulaire
191 * @param string $redirect
192 * URL de redirection après les traitements
193 * @return array
194 * Retours du traitement
195 **/
196 function formulaires_admin_plugin_traiter_dist($voir = 'actif', $verrouille = 'non', $id_paquet = '', $redirect = '') {
197
198 $retour = array();
199
200 if (_request('valider_actions')) {
201 refuser_traiter_formulaire_ajax();
202 // Ajout de la liste des actions à l'actionneur
203 // c'est lui qui va effectuer rellement les actions
204 // lors de l'appel de action/actionner
205 $actions = unserialize(_request('_todo'));
206 include_spip('inc/svp_actionner');
207 svp_actionner_traiter_actions_demandees($actions, $retour, $redirect);
208 }
209
210 $retour['editable'] = true;
211
212 return $retour;
213 }