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

Last change on this file since 80618 was 80618, checked in by cedric@…, 6 years ago

A l'installation quand on migre les formulaires de f&t on conserve le meme id c'est beaucoup plus comprehensible (et tant pis si il y a quelques trous)

File size: 8.1 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        include_spip('base/upgrade');
57        maj_plugin($nom_meta_base_version, $version_cible, $maj);
58}
59
60/**
61 * Désinstallation/suppression des tables de formidable
62 *
63 * @param string $nom_meta_base_version
64 *     Nom de la meta informant de la version du schéma de données du plugin installé dans SPIP
65 * @return void
66 */
67function formidable_vider_tables($nom_meta_base_version){
68
69        include_spip('inc/meta');
70        include_spip('base/abstract_sql');
71
72        // On efface les tables du plugin
73        sql_drop_table('spip_formulaires');
74        sql_drop_table('spip_formulaires_reponses');
75        sql_drop_table('spip_formulaires_reponses_champs');
76        sql_drop_table('spip_formulaires_liens');
77
78        // on efface les champs d'import de f&t si il y a lieu
79        $trouver_table = charger_fonction("trouver_table","base");
80        if ($trouver_table('spip_forms')){
81                sql_alter("TABLE spip_forms DROP id_formulaire");
82        }
83        if ($trouver_table('spip_forms_donnees')){
84                sql_alter("TABLE spip_forms_donnees DROP id_formulaires_reponse");
85        }
86
87
88        // On efface la version entregistrée
89        effacer_meta($nom_meta_base_version);
90}
91
92/**
93 * Associer les <formXX> issus de f&t aux articles concernes
94 */
95function formidable_associer_forms(){
96        include_spip("inc/rechercher");
97        include_spip("inc/editer_liens");
98        $forms = sql_allfetsel("*","spip_formulaires","identifiant REGEXP ".sql_quote('^form[0-9]+$'));
99        foreach($forms as $form){
100                if (!sql_countsel("spip_formulaires_liens","id_formulaire=".intval($form['id_formulaire']))){
101                        $articles = array();
102                        $id = $form['identifiant'];
103                        #var_dump($id);
104                        $res = recherche_en_base("/<{$id}[>|]/","article");
105                        #var_dump($res);
106                        if (count($res) AND isset($res['article'])){
107                                foreach($res['article'] as $id_article=>$details){
108                                        $articles[] = $id_article;
109                                }
110                        }
111                        #var_dump($form['id_formulaire']);
112                        #var_dump($articles);
113                        objet_associer(array('formulaire'=>array($form['id_formulaire'])),array('article'=>$articles));
114                }
115                if (time()>_TIME_OUT)
116                        return;
117        }
118}
119
120/**
121 * Importer les formulaires de f&t
122 */
123function formidable_importer_forms(){
124        $trouver_table = charger_fonction("trouver_table","base");
125        if ($trouver_table('spip_forms')){
126                sql_alter("TABLE spip_forms ADD id_formulaire bigint(21) NOT NULL DEFAULT 0");
127
128                include_spip("echanger/formulaire/forms");
129
130                $forms = sql_allfetsel("*","spip_forms",'id_formulaire=0 AND type_form='.sql_quote('')." OR type_form=".sql_quote('sondage'),'','id_form');
131                foreach($forms as $form){
132                        $formulaire = array();
133                        // configurer le formulaire (titre etc)
134                        forms_configure_formulaire($form,$formulaire);
135
136                        // identifiant formXX puisqu'on est en installation, pas de risque de conflits
137                        // et facilite la migration de modele
138                        $formulaire['identifiant'] = "form".$form['id_form'];
139                        // on peut faire ca aussi puisqu'on est a l'installation
140                        $formulaire['id_formulaire'] = $form['id_form'];
141
142                        $fields = sql_allfetsel("*","spip_forms_champs","id_form=".intval($form['id_form']),"","rang");
143                        foreach($fields as $field){
144                                $choix = sql_allfetsel("*","spip_forms_champs_choix","id_form=".intval($form['id_form'])." AND champ=".sql_quote($field['champ']),'','rang');
145                                if (count($choix))
146                                        $field['choix'] = $choix;
147
148                                if ($saisie = forms_champ_vers_saisie($field))
149                                        $formulaire['saisies'][] = $saisie;
150                        }
151
152                        // les traitements
153                        forms_configure_traitement_formulaire($form,$formulaire);
154
155                        // si ce formulaire a des reponses on le met en publie
156                        if (sql_countsel("spip_forms_donnees","id_form=".intval($form['id_form'])))
157                                $formulaire['statut'] = 'publie';
158
159                        $id_formulaire = forms_importe_en_base($formulaire);
160                        spip_log("Import spip_forms #".$form['id_form']." en spip_formulaires #$id_formulaire","maj"._LOG_INFO_IMPORTANTE);
161
162                        sql_update('spip_forms',array('id_formulaire'=>$id_formulaire),'id_form='.intval($form['id_form']));
163
164                        if (time()>_TIME_OUT)
165                                return;
166                }
167
168        }
169
170        include_spip("inc/drapeau_edition");
171        debloquer_tous($GLOBALS['visiteur_session']['id_auteur']);
172}
173
174function formidable_importer_forms_donnees(){
175        $trouver_table = charger_fonction("trouver_table","base");
176        if ($trouver_table('spip_forms')){
177                sql_alter("TABLE spip_forms_donnees ADD id_formulaires_reponse bigint(21) NOT NULL DEFAULT 0");
178
179                // 2 champs de plus pour ne pas perdre des donnees
180                sql_alter("TABLE spip_formulaires_reponses ADD url varchar(255) NOT NULL default ''");
181                sql_alter("TABLE spip_formulaires_reponses ADD confirmation varchar(10) NOT NULL default ''");
182
183                // table de correspondance id_form=>id_formulaire
184                $rows = sql_allfetsel("id_form,id_formulaire","spip_forms","id_formulaire>0");
185                $trans = array();
186                foreach($rows as $row)
187                        $trans[$row['id_form']] = $row['id_formulaire'];
188
189                $rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100');
190                do {
191
192                        foreach($rows as $row){
193
194                                #var_dump($row);
195                                $reponse = array(
196                                        "id_formulaire" => $trans[$row['id_form']],
197                                        "date" => $row["date"],
198                                        "ip" => $row["ip"],
199                                        "id_auteur" => $row["id_auteur"],
200                                        "cookie" => $row["cookie"],
201                                        "statut" => $row["statut"],
202                                        "url" => $row["url"],
203                                        "confirmation" => $row["confirmation"],
204                                );
205
206                                #var_dump($reponse);
207                                $id_formulaires_reponse = sql_insertq("spip_formulaires_reponses",$reponse);
208                                #var_dump($id_formulaires_reponse);
209                                if ($id_formulaires_reponse){
210                                        $donnees = sql_allfetsel("$id_formulaires_reponse as id_formulaires_reponse,champ as nom,valeur","spip_forms_donnees_champs","id_donnee=".intval($row['id_donnee']));
211                                        sql_insertq_multi("spip_formulaires_reponses_champs",$donnees);
212                                        // et on marque la donnee pour ne pas la rejouer
213                                        sql_update("spip_forms_donnees",array("id_formulaires_reponse"=>$id_formulaires_reponse),"id_donnee=".intval($row['id_donnee']));
214                                }
215                                if (time()>_TIME_OUT)
216                                        return;
217                        }
218
219                        if (time()>_TIME_OUT)
220                                return;
221
222                } while ($rows = sql_allfetsel("*","spip_forms_donnees",sql_in('id_form',array_keys($trans))." AND id_formulaires_reponse=0",'','id_donnee','0,100'));
223
224        }
225
226}
Note: See TracBrowser for help on using the repository browser.