[PLUGINS] +set de base
[lhc/web/www.git] / www / plugins / gis / action / editer_gis.php
1 <?php
2
3 if (!defined("_ECRIRE_INC_VERSION")) return;
4
5 include_spip('inc/autoriser');
6
7 function action_editer_gis_dist($arg=null) {
8 if (is_null($arg)){
9 $securiser_action = charger_fonction('securiser_action', 'inc');
10 $arg = $securiser_action();
11 }
12
13 // si id_gis n'est pas un nombre, c'est une creation
14 if (!$id_gis = intval($arg)) {
15 if (!autoriser('creer','gis') or !$id_gis = gis_inserer())
16 return array(false,_L('echec'));
17 }
18 $err = gis_modifier($id_gis);
19 return array($id_gis,$err);
20 }
21
22 /**
23 * Fonction d'insertion d'un gis vide
24 *
25 * @return int/false $id_gis : l'identifiant numérique du point ou false en cas de non création
26 */
27 function gis_inserer() {
28 $champs = array();
29
30 // Envoyer aux plugins
31 $champs = pipeline('pre_insertion', array(
32 'args' => array(
33 'table' => 'spip_gis',
34 ),
35 'data' => $champs
36 ));
37
38 $id_gis = sql_insertq("spip_gis", $champs);
39
40 pipeline('post_insertion',
41 array(
42 'args' => array(
43 'table' => 'spip_gis',
44 'id_objet' => $id_gis
45 ),
46 'data' => $champs
47 )
48 );
49 return $id_gis;
50 }
51
52 /**
53 * Enregistrer certaines modifications d'un gis
54 *
55 * @param int $id_gis : l'identifiant numérique du point
56 * @param array $c : un array des valeurs à mettre en base (par défaut false, on récupère les valeurs passées en dans le POST)
57 */
58 /**
59 * Appelle toutes les fonctions de modification d'un point gis
60 * $err est de la forme chaine de langue ou vide si pas d'erreur
61 * http://doc.spip.org/@articles_set
62 *
63 * @param $id_gis
64 * @param null $set
65 * @return string
66 */
67 function gis_modifier($id_gis, $set=null) {
68 include_spip('inc/modifier');
69 include_spip('inc/filtres');
70 $c = collecter_requests(
71 // white list
72 objet_info('gis','champs_editables'),
73 // black list
74 array('id_objet','objet'),
75 // donnees eventuellement fournies
76 $set
77 );
78
79 if ($err = objet_modifier_champs('gis', $id_gis,
80 array(
81 //'nonvide' => array('nom' => _T('info_sans_titre')),
82 'invalideur' => "id='gis/$id_gis'",
83 ),
84 $c))
85 return $err;
86
87 // lier a un parent ?
88 $c = collecter_requests(array('id_objet', 'objet'),array(),$set);
89 if (isset($c['id_objet']) AND intval($c['id_objet']) AND isset($c['objet']) AND $c['objet']) {
90 lier_gis($id_gis, $c['objet'], $c['id_objet']);
91 }
92
93 return $err;
94 }
95
96
97 /**
98 * Associer un point géolocalisé a des objets listes sous forme
99 * array($objet=>$id_objets,...)
100 * $id_objets peut lui meme etre un scalaire ou un tableau pour une liste d'objets du meme type
101 *
102 * on peut passer optionnellement une qualification du (des) lien(s) qui sera
103 * alors appliquee dans la foulee.
104 * En cas de lot de liens, c'est la meme qualification qui est appliquee a tous
105 *
106 * @param int $id_gis
107 * @param array $objets
108 * @param array $qualif
109 * @return string
110 */
111 function gis_associer($id_gis,$objets, $qualif = null){
112 include_spip('action/editer_liens');
113 $res = objet_associer(array('gis'=>$id_gis), $objets, $qualif);
114 include_spip('inc/invalideur');
115 suivre_invalideur("id='gis/$id_gis'");
116 return $res;
117 }
118
119 /**
120 * Dossocier un point géolocalisé des objets listes sous forme
121 * array($objet=>$id_objets,...)
122 * $id_objets peut lui meme etre un scalaire ou un tableau pour une liste d'objets du meme type
123 *
124 * un * pour $id_auteur,$objet,$id_objet permet de traiter par lot
125 *
126 * @param int $id_gis
127 * @param array $objets
128 * @return string
129 */
130 function gis_dissocier($id_gis,$objets){
131 include_spip('action/editer_liens');
132 $res = objet_dissocier(array('gis'=>$id_gis), $objets);
133 include_spip('inc/invalideur');
134 suivre_invalideur("id='gis/$id_gis'");
135 return $res;
136 }
137
138
139
140 /**
141 * Supprimer définitivement un point géolocalisé
142 *
143 * @param int $id_gis identifiant numérique du point
144 * @return int|false 0 si réussite, false dans le cas ou le point n'existe pas
145 */
146 function gis_supprimer($id_gis){
147 $valide = sql_getfetsel('id_gis','spip_gis','id_gis='.intval($id_gis));
148 if($valide && autoriser('supprimer','gis',$valide)){
149 sql_delete("spip_gis_liens", "id_gis=".intval($id_gis));
150 sql_delete("spip_gis", "id_gis=".intval($id_gis));
151 $id_gis = 0;
152 include_spip('inc/invalideur');
153 suivre_invalideur("id='id_gis/$id_gis'");
154 return $id_gis;
155 }
156 return false;
157 }
158
159
160 /**
161 * Délier un point géolocalisé d'un objet SPIP
162 *
163 * @param int $id_gis identifiant numérique du point
164 * @param string $objet Le type de l'objet à lier
165 * @param int $id_objet L'identifiant numérique de l'objet lié
166 *
167 * @return bool : true si la suppression de la liaison s'est bien passée, false à l'inverse
168 */
169 function delier_gis($id_gis, $objet, $id_objet){
170 //$objet = objet_type($objet);
171 if ($id_objet AND $id_gis
172 AND preg_match('/^[a-z0-9_]+$/i', $objet) # securite
173 AND autoriser('delier','gis',$id_gis,$GLOBALS['visiteur_session'],array('objet' => $objet,'id_objet'=>$id_objet))
174 ) {
175 gis_dissocier($id_gis,array($objet=>$id_objet));
176 return true;
177 }
178 return false;
179 }
180
181 /**
182 * Lier un point géolocalisé à un objet SPIP
183 *
184 * @param int $id_gis identifiant numérique du point
185 * @param string $objet Le type de l'objet à lier
186 * @param int $id_objet L'identifiant numérique de l'objet lié
187 *
188 * @return bool : true si la liaison s'est bien passée, false à l'inverse
189 */
190 function lier_gis($id_gis, $objet, $id_objet){
191 //$objet = objet_type($objet);
192 if ($id_objet AND $id_gis
193 AND preg_match('/^[a-z0-9_]+$/i', $objet) # securite
194 AND !sql_getfetsel("id_gis", "spip_gis_liens", "id_gis=$id_gis AND id_objet=$id_objet AND objet=".sql_quote($objet))
195 AND autoriser('lier','gis',$id_gis,$GLOBALS['visiteur_session'],array('objet' => $objet,'id_objet'=>$id_objet))
196 ) {
197 gis_associer($id_gis,array($objet=>$id_objet));
198 return true;
199 }
200 return false;
201 }
202
203 function insert_gis() {return gis_inserer();}
204 function revisions_gis($id_gis, $c=false) {return gis_modifier($id_gis,$c);}
205 function supprimer_gis($id_gis){return gis_supprimer($id_gis);}
206
207 ?>