source: spip-zone/_plugins_/formidable/trunk/formidable_administrations.php @ 92670

Last change on this file since 92670 was 92670, checked in by prigent.yohann@…, 4 years ago

Formidable 2.9.4 : On permet d’avoir un champ où les valeurs sont uniques. Par exemple un champ email où 2 personnes ne peuvent pas remplir le même email.

File size: 12.3 KB
Line 
1<?php
2
3/**
4 * Fichier gérant l'installation et désinstallation du plugin
5 *
6 * @package SPIP\Formidable\Installation
7**/
8
9// Sécurité
10if (!defined("_ECRIRE_INC_VERSION")) return;
11
12/**
13 * Installation/maj des tables de formidable...
14 *
15 * @param string $nom_meta_base_version
16 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
17 * @param string $version_cible
18 *     Version du schéma de données dans ce plugin (déclaré dans paquet.xml)
19 * @return void
20 */
21function formidable_upgrade($nom_meta_base_version, $version_cible){
22        // Création des tables
23        include_spip('base/create');
24        include_spip('base/abstract_sql');
25
26        $maj = array();
27        $maj['create'] = array(
28                array('maj_tables',array(
29                        'spip_formulaires',
30                        'spip_formulaires_reponses',
31                        'spip_formulaires_reponses_champs',
32                        'spip_formulaires_liens')),
33                array('formidable_importer_forms'),
34                array('formidable_importer_forms_donnees'),
35                array('formidable_associer_forms'),
36        );
37
38        // Ajout du choix de ce qu'on affiche à la fin des traitements
39        $maj['0.4.0'] = array(array('maj_tables',array('spip_formulaires')));
40        // Ajout d'une URL de redirection
41        $maj['0.5.0'] = array(array('maj_tables',array('spip_formulaires')));
42        // Modif du type du message de retour pour pouvoir mettre plus de chose
43        $maj['0.5.1'] = array(array('sql_alter','TABLE spip_formulaires CHANGE message_retour message_retour text NOT NULL default ""'));
44        // Passer le champ saisies en longtext pour permettre d'y stocker des formulaires longs
45        $maj['0.5.2'] = array(array('sql_alter','TABLE spip_formulaires CHANGE saisies saisies longtext NOT NULL default ""'));
46        // Ajouter un champ date de création
47        $maj['0.5.3'] = array(array('sql_alter','TABLE spip_formulaires ADD date_crea datetime NOT NULL DEFAULT "0000-00-00 00:00:00"'));
48        // Renommer la date de création (pas d'abbréviations dans les noms)
49        $maj['0.5.5'] = array(array('sql_alter','TABLE spip_formulaires CHANGE date_crea date_creation datetime NOT NULL DEFAULT "0000-00-00 00:00:00"'));
50
51        // statut publie sur les formulaires sans statut
52        $maj['0.5.6'] = array(
53                array('sql_updateq','spip_formulaires',array('statut'=>'publie'),"statut=".sql_quote('')),
54        );
55
56        $maj['0.6.0'] = array(
57                array('sql_alter','TABLE spip_formulaires_reponses_champs RENAME TO spip_formulaires_reponses_champs_bad'),
58                array('maj_tables',array('spip_formulaires_reponses_champs')),
59                array('formidable_transferer_reponses_champs'),
60                array('sql_drop_table','spip_formulaires_reponses_champs_bad'),
61        );
62        $maj['0.6.1'] = array(
63                array('formidable_unifier_reponses_champs'),
64        );
65        $maj['0.6.3'] = array(
66                array('sql_alter','TABLE spip_formulaires_reponses_champs ADD UNIQUE reponse (id_formulaires_reponse,nom)'),
67        );
68        $maj['0.6.4'] = array(
69                // champ resume_reponse
70                array('maj_tables',array('spip_formulaires')),
71        );
72        // Pouvoir rendre un champ unique
73        $maj['0.6.5'] = array(
74                // champ resume_reponse
75                array('maj_tables',array('spip_formulaires')),
76        );
77
78        include_spip('base/upgrade');
79        maj_plugin($nom_meta_base_version, $version_cible, $maj);
80}
81
82
83function formidable_unifier_reponses_champs(){
84
85        $rows = sql_allfetsel("DISTINCT id_formulaires_reponses_champ,id_formulaires_reponse,nom,count(id_formulaires_reponse) AS N","spip_formulaires_reponses_champs",'nom LIKE '.sql_quote('multiple%').' OR nom LIKE '.sql_quote('mot%'),'concat( id_formulaires_reponse, nom )','id_formulaires_reponse','0,100','N>1');
86        do {
87
88
89                foreach($rows as $row){
90
91                        #var_dump($row);
92
93                        // pour chaque reponse on recupere tous les champs
94                        $reponse = sql_allfetsel("*","spip_formulaires_reponses_champs","id_formulaires_reponse=".intval($row['id_formulaires_reponse']));
95                        spip_log("id_formulaires_reponse ".$row['id_formulaires_reponse'],"formidable_unifier_reponses_champs"._LOG_INFO_IMPORTANTE);
96                        // on les reinsere un par un dans la nouvelle table propre
97                        $data = array();
98                        foreach($reponse as $champ){
99                                $data[$champ['nom']][] = $champ;
100                        }
101
102                        foreach($data as $nom=>$champs){
103                                if (count($champs)>1){
104                                        #var_dump($champs);
105                                        $keep = $champs[0]['id_formulaires_reponses_champ'];
106                                        $delete = array();
107                                        $valeurs = array();
108                                        foreach($champs as $champ){
109                                                $valeurs[] = $champ['valeur'];
110                                                if ($champ['id_formulaires_reponses_champ']!==$keep)
111                                                        $delete[] = $champ['id_formulaires_reponses_champ'];
112                                        }
113                                        $valeurs = serialize($valeurs);
114                                        #var_dump($valeurs);
115                                        #var_dump($keep);
116                                        #var_dump($delete);
117                                        sql_updateq('spip_formulaires_reponses_champs',array('valeur'=>$valeurs),'id_formulaires_reponses_champ='.intval($keep));
118                                        sql_delete('spip_formulaires_reponses_champs',sql_in('id_formulaires_reponses_champ',$delete));
119                                        //die();
120                                }
121                        }
122                        #var_dump($data);
123                        //die('nothing?');
124
125                        if (time()>_TIME_OUT)
126                                return;
127                }
128
129                if (time()>_TIME_OUT)
130                        return;
131
132        }
133        while ($rows = sql_allfetsel("DISTINCT id_formulaires_reponses_champ,id_formulaires_reponse,nom,count( id_formulaires_reponse ) AS N","spip_formulaires_reponses_champs",'nom LIKE '.sql_quote('multiple%').' OR nom LIKE '.sql_quote('mot%'),'concat( id_formulaires_reponse, nom )','id_formulaires_reponse','0,100','N>1'));
134        //die('fini?');
135}
136
137
138function formidable_transferer_reponses_champs(){
139
140        $rows = sql_allfetsel("DISTINCT id_formulaires_reponse","spip_formulaires_reponses_champs_bad",'','id_formulaires_reponse','','0,100');
141        do {
142
143                foreach($rows as $row){
144
145                        // pour chaque reponse on recupere tous les champs
146                        $reponse = sql_allfetsel("*","spip_formulaires_reponses_champs_bad","id_formulaires_reponse=".intval($row['id_formulaires_reponse']));
147                        // on les reinsere un par un dans la nouvelle table propre
148                        foreach($reponse as $champ){
149                                sql_insertq("spip_formulaires_reponses_champs",$champ);
150                        }
151                        // et on les vire de la mauvaise
152                        sql_delete("spip_formulaires_reponses_champs_bad","id_formulaires_reponse=".intval($row['id_formulaires_reponse']));
153
154                        if (time()>_TIME_OUT)
155                                return;
156                }
157
158                if (time()>_TIME_OUT)
159                        return;
160
161        }
162        while ($rows = sql_allfetsel("DISTINCT id_formulaires_reponse","spip_formulaires_reponses_champs_bad",'','id_formulaires_reponse','','0,100'));
163
164}
165
166
167/**
168 * Désinstallation/suppression des tables de formidable
169 *
170 * @param string $nom_meta_base_version
171 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
172 * @return void
173 */
174function formidable_vider_tables($nom_meta_base_version){
175
176        include_spip('inc/meta');
177        include_spip('base/abstract_sql');
178
179        // On efface les tables du plugin
180        sql_drop_table('spip_formulaires');
181        sql_drop_table('spip_formulaires_reponses');
182        sql_drop_table('spip_formulaires_reponses_champs');
183        sql_drop_table('spip_formulaires_liens');
184
185        // on efface les champs d'import de f&t si il y a lieu
186        $trouver_table = charger_fonction("trouver_table","base");
187        if ($trouver_table('spip_forms')){
188                sql_alter("TABLE spip_forms DROP id_formulaire");
189        }
190        if ($trouver_table('spip_forms_donnees')){
191                sql_alter("TABLE spip_forms_donnees DROP id_formulaires_reponse");
192        }
193
194
195        // On efface la version entregistrée
196        effacer_meta($nom_meta_base_version);
197}
198
199/**
200 * Associer les <formXX> issus de f&t aux articles concernes
201 */
202function formidable_associer_forms(){
203        include_spip("inc/rechercher");
204        include_spip("inc/editer_liens");
205        $forms = sql_allfetsel("*","spip_formulaires","identifiant REGEXP ".sql_quote('^form[0-9]+$'));
206        foreach($forms as $form){
207                if (!sql_countsel("spip_formulaires_liens","id_formulaire=".intval($form['id_formulaire']))){
208                        $articles = array();
209                        $id = $form['identifiant'];
210                        #var_dump($id);
211                        $res = recherche_en_base("/<{$id}[>|]/","article");
212                        #var_dump($res);
213                        if (count($res) AND isset($res['article'])){
214                                foreach($res['article'] as $id_article=>$details){
215                                        $articles[] = $id_article;
216                                }
217                        }
218                        #var_dump($form['id_formulaire']);
219                        #var_dump($articles);
220                        objet_associer(array('formulaire'=>array($form['id_formulaire'])),array('article'=>$articles));
221                }
222                if (time()>_TIME_OUT)
223                        return;
224        }
225}
226
227/**
228 * Importer les formulaires de f&t
229 */
230function formidable_importer_forms(){
231        $trouver_table = charger_fonction("trouver_table","base");
232        if ($trouver_table('spip_forms')){
233                sql_alter("TABLE spip_forms ADD id_formulaire bigint(21) NOT NULL DEFAULT 0");
234
235                include_spip("echanger/formulaire/forms");
236
237                $forms = sql_allfetsel("*","spip_forms",'id_formulaire=0 AND type_form='.sql_quote('')." OR type_form=".sql_quote('sondage'),'','id_form');
238                foreach($forms as $form){
239                        $formulaire = array();
240                        // configurer le formulaire (titre etc)
241                        forms_configure_formulaire($form,$formulaire);
242
243                        // identifiant formXX puisqu'on est en installation, pas de risque de conflits
244                        // et facilite la migration de modele
245                        $formulaire['identifiant'] = "form".$form['id_form'];
246                        // on peut faire ca aussi puisqu'on est a l'installation
247                        $formulaire['id_formulaire'] = $form['id_form'];
248
249                        $fields = sql_allfetsel("*","spip_forms_champs","id_form=".intval($form['id_form']),"","rang");
250                        foreach($fields as $field){
251                                $choix = sql_allfetsel("*","spip_forms_champs_choix","id_form=".intval($form['id_form'])." AND champ=".sql_quote($field['champ']),'','rang');
252                                if (count($choix))
253                                        $field['choix'] = $choix;
254
255                                if ($saisie = forms_champ_vers_saisie($field))
256                                        $formulaire['saisies'][] = $saisie;
257                        }
258
259                        // les traitements
260                        forms_configure_traitement_formulaire($form,$formulaire);
261
262                        // si ce formulaire a des reponses on le met en publie
263                        if (sql_countsel("spip_forms_donnees","id_form=".intval($form['id_form'])))
264                                $formulaire['statut'] = 'publie';
265
266                        $id_formulaire = forms_importe_en_base($formulaire);
267                        spip_log("Import spip_forms #".$form['id_form']." en spip_formulaires #$id_formulaire","maj"._LOG_INFO_IMPORTANTE);
268
269                        sql_update('spip_forms',array('id_formulaire'=>$id_formulaire),'id_form='.intval($form['id_form']));
270
271                        if (time()>_TIME_OUT)
272                                return;
273                }
274
275        }
276
277        include_spip("inc/drapeau_edition");
278        debloquer_tous($GLOBALS['visiteur_session']['id_auteur']);
279}
280
281function formidable_importer_forms_donnees(){
282        $trouver_table = charger_fonction("trouver_table","base");
283        if ($trouver_table('spip_forms')){
284                sql_alter("TABLE spip_forms_donnees ADD id_formulaires_reponse bigint(21) NOT NULL DEFAULT 0");
285
286                // 2 champs de plus pour ne pas perdre des donnees
287                sql_alter("TABLE spip_formulaires_reponses ADD url varchar(255) NOT NULL default ''");
288                sql_alter("TABLE spip_formulaires_reponses ADD confirmation varchar(10) NOT NULL default ''");
289
290                // table de correspondance id_form=>id_formulaire
291                $rows = sql_allfetsel("id_form,id_formulaire","spip_forms","id_formulaire>0");
292                $trans = array();
293                foreach($rows as $row)
294                        $trans[$row['id_form']] = $row['id_formulaire'];
295
296                $rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100');
297                do {
298
299                        foreach($rows as $row){
300
301                                #var_dump($row);
302                                $reponse = array(
303                                        "id_formulaires_reponse"=>$row['id_donnee'], // conserver le meme id par facilite (on est sur une creation de base)
304                                        "id_formulaire" => $trans[$row['id_form']],
305                                        "date" => $row["date"],
306                                        "ip" => $row["ip"],
307                                        "id_auteur" => $row["id_auteur"],
308                                        "cookie" => $row["cookie"],
309                                        "statut" => $row["statut"],
310                                        "url" => $row["url"],
311                                        "confirmation" => $row["confirmation"],
312                                );
313
314                                #var_dump($reponse);
315                                $id_formulaires_reponse = sql_insertq("spip_formulaires_reponses",$reponse);
316                                #var_dump($id_formulaires_reponse);
317                                if ($id_formulaires_reponse){
318                                        $donnees = sql_allfetsel("$id_formulaires_reponse as id_formulaires_reponse,champ as nom,valeur","spip_forms_donnees_champs","id_donnee=".intval($row['id_donnee']));
319                                        $data = array();
320                                        foreach($donnees AS $donnee){
321                                                $data[$donnee['nom']][] = $donnee;
322                                        }
323                                        $ins = array();
324                                        foreach($data as $nom=>$valeurs){
325                                                if (count($valeurs)==1)
326                                                        $ins[] = reset($valeurs);
327                                                else {
328                                                        $v = array();
329                                                        foreach($valeurs as $valeur)
330                                                                $v[] = $valeur['valeur'];
331                                                        $valeurs[0]['valeur'] = serialize($v);
332                                                        $ins[] = $valeurs[0];
333                                                }
334                                        }
335                                        sql_insertq_multi("spip_formulaires_reponses_champs",$ins);
336                                        // et on marque la donnee pour ne pas la rejouer
337                                        sql_update("spip_forms_donnees",array("id_formulaires_reponse"=>$id_formulaires_reponse),"id_donnee=".intval($row['id_donnee']));
338                                }
339                                if (time()>_TIME_OUT)
340                                        return;
341                        }
342
343                        if (time()>_TIME_OUT)
344                                return;
345
346                } while ($rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100'));
347
348        }
349
350}
Note: See TracBrowser for help on using the repository browser.