Subversion Repositories eFlore/Applications.cel

Rev

Rev 3937 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
416 aurelien 1
<?php
2462 jpm 2
// declare(encoding='UTF-8');
416 aurelien 3
/**
522 jpm 4
 * Service fournissant des informations concernant les images du CEL au format RSS1, RSS2 ou ATOM.
3743 delphine 5
 
1338 jpm 6
 *
2462 jpm 7
 * @internal   Mininum PHP version : 5.2
8
 * @category   CEL
9
 * @package    Services
10
 * @subpackage Syndication
11
 * @version    0.1
12
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
13
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
14
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
15
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
16
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
17
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
416 aurelien 18
 */
19
class CelSyndicationImage extends Cel {
3743 delphine 20
 
21
    private $parametres_origines = null;
22
    private $format = null;
23
    private $service = null;
24
    private $squelette = null;
25
    private $squelette_dossier = null;
26
    private $auteurs = array();
27
    private $flux = array();
28
 
29
    private $format_image = 'XL';
30
 
31
    private $criteres = array(
32
        'utilisateur' => 'b.courriel_utilisateur',
33
        'commune' => 'b.zone_geo',
34
        'dept' => 'b.dept',
35
        'taxon' => 'b.nom_ret',
36
        'num_taxon' => 'b.nt',
37
        'num_nom' => 'b.nom_sel_nn',
38
        'commentaire' => 'c.commentaire',
39
        'date' => 'c.date_prise_de_vue',
40
        'tag' => 'tag',
41
        'motcle' => 'tag',
42
        'projet' => 'projet',
43
        'referentiel' => 'referentiel',
44
        'groupe_zones_geo' => 'groupe_zones_geo'
45
    );
46
 
47
    /**
48
     * Méthode appelée avec une requête de type GET.
49
     */
50
    public function getElement($params = array()) {
51
        // Initialisation des variables
52
        $this->parametres_origines = $params;
53
        $info = array();
54
        $contenu = '';
55
 
56
        if (! $this->etreFluxAdmin() || $this->authentifierAdmin()) {
57
            // Pré traitement des paramêtres
58
            $pour_bdd = false;
59
            $p = $this->traiterParametres(array('service', 'format'), $params, $pour_bdd);
60
            extract($p);
61
            $this->parametres = $params;
62
            $this->squelette_dossier = dirname(__FILE__).DIRECTORY_SEPARATOR.'squelettes'.DIRECTORY_SEPARATOR;
63
 
64
            // Récupération de la liste des flux
65
            $this->chargerListeDesFlux();
66
 
67
            // Chargement du bon type de service demandé
68
            if (isset($service)) {
69
                $this->service = $this->traiterNomService($service);
70
                $methode = $this->getNomMethodeService();
71
                if (method_exists($this, $methode)) {
72
                    if (isset($format) && preg_match('/^(?:rss1|rss2|atom)$/i', $format)) {
73
                        // Mise en minuscule de l'indication du format
74
                        $this->format = strtolower($format);
75
                        // Définition du fichier squelette demandé
76
                        $this->squelette = $this->squelette_dossier.$this->format.'.tpl.xml';
77
                    } else if (isset($this->flux[$this->service])) {
78
                        $this->format = '';
79
                        $this->messages[] = "Le service CEL Syndication nécessite d'indiquer en second paramètre le format : rss1, rss2 ou atom.";
80
                    }
81
 
82
                    if (!isset($this->flux[$this->service]) || isset($this->format)) {
83
                        // Suppression des deux premiers paramètres (service et format)  pour le reste des méthodes
84
                        array_shift($this->parametres);
85
                        array_shift($this->parametres);
86
 
87
                        // Récupération du contenu à renvoyer
88
                        $contenu = $this->$methode();
89
                    }
90
                } else {
91
                    $this->messages[] = "Le type d'information demandé '$this->service' n'est pas disponible.";
92
                }
93
            } else {
94
                $this->messages[] = "Le service CEL Syndication Image nécessite d'indiquer en premier paramètre le type d'information demandé.";
95
            }
96
        }
97
 
98
        // Envoie sur la sortie standard
99
        $encodage = 'utf-8';
100
        $mime = $this->getTypeMime();
101
        $formatage_json = $this->getFormatageJson();
102
        $this->envoyer($contenu, $mime, $encodage, $formatage_json);
103
    }
104
 
105
    private function chargerListeDesFlux() {
106
        $this->setFlux('simple', 'Nouvelles images liées à une observation dans le CEL',
107
            "Ce flux fournit l'url des nouvelles images du CEL liées à une observation.");
108
        $this->setFlux('complet', 'Nouvelles images liées à une observation dans le CEL (détails)',
109
            "Ce flux fournit les informations sur les nouvelles images du CEL liées à une observation.");
110
        $this->setFlux('par-mots-cles', 'Flux de syndication obsolète',
111
            "Ce flux est désormais accessible via le flux multicriteres/atom/M?tag='mot-cle'.");
112
        $this->setFlux('par-commune','Flux de syndication obsolète',
113
            "Ce flux  est désormais accessible via le flux multicriteres/atom/M?commune='commune'.");
114
        $this->setFlux('multicriteres','Flux de syndication des nouvelles images liées à une observation publique du CEL '.
115
            'filtrées par un ou plusieurs critères',
116
            "Ce flux fournit des informations sur les nouvelles images liées à une observation du CEL filtrées par ".
117
            "auteur (mail), commune (nom), departement (code postal), taxon (nom scientifique), commentaire, tag ".
118
            "et/ou date.");
119
    }
120
 
121
    private function setFlux($nom, $titre, $description) {
122
        $url_base = $this->config['settings']['baseURLAbsoluDyn'].'CelSyndicationImage/';
123
        $formats = array('atom', 'rss2', 'rss1');
124
        $flux = array();
125
        foreach ($formats as $format) {
126
            $url = $url_base.$nom.'/'.$format;
127
            $flux[$format] = $url;
128
        }
129
        $this->flux[$nom] = array('titre' => $titre, 'description' => $description, 'urls' => $flux);
130
    }
131
 
132
    private function getFlux($nom) {
133
        return isset($this->flux[$nom]) ? $this->flux[$nom] : array();
134
    }
135
 
136
    private function traiterNomService($nom) {
137
        $nom = strtolower($nom);
138
        return $nom;
139
    }
140
 
141
    private function getNomMethodeService() {
142
        $methode = '';
143
        $service_formate = str_replace(' ', '', ucwords(implode(' ', explode('-', $this->service))));
144
        $methode = 'getService'.$service_formate;
145
        return $methode;
146
    }
147
 
148
    private function getUrlBase() {
149
        $url_base = sprintf($this->config['settings']['baseURLAbsolu'], get_class($this).'/');
150
        return $url_base;
151
    }
152
 
153
    private function getUrlServiceBase() {
154
        $url_service = $this->getUrlBase().implode('/', $this->parametres_origines);
155
        return $url_service;
156
    }
157
 
158
    private function getTypeMime() {
159
        $mime = '';
160
        switch ($this->format) {
161
            case 'atom' :
162
                $mime = 'application/atom+xml';
163
                break;
164
            case 'rss1' :
165
            case 'rss2' :
166
                $mime = 'application/rss+xml';
167
                break;
168
            case 'opml' :
169
                $mime = 'text/x-opml';
170
                break;
171
            default:
172
                $mime = 'text/html';
173
        }
174
        return $mime;
175
    }
176
 
177
    private function getFormatageJson() {
178
        $json = false;
179
        switch ($this->service) {
180
            case 'liste-des-flux' :
181
                $json = true;
182
                break;
183
            default:
184
                $json = false;
185
        }
186
        return $json;
187
    }
188
 
189
    private function creerCategorie($element) {
190
        $categorie = '';
191
        $categorie = 'Image';
192
        $categorie = $this->nettoyerTexte($categorie);
193
        return $categorie;
194
    }
195
 
196
    private function etreFluxAdmin() {
197
        return (isset($_GET['admin']) && $_GET['admin'] == '1') ? true : false;
198
    }
199
 
200
    private function creerUrlService() {
201
        $url_service = $this->getUrlServiceBase();
202
        if (count($_GET) > 0) {
203
            $parametres_get = array();
204
            foreach ($_GET as $cle => $valeur) {
205
                $parametres_get[] = $cle.'='.$valeur;
206
            }
207
            $url_service .= '?'.implode('&amp;', $parametres_get);
208
        }
209
        return $url_service;
210
    }
211
 
212
    protected function executerRequete($requete, $retour = 'All', $mode = PDO::FETCH_ASSOC) {
213
        $infos = null;
214
        try {
215
            $infos = Cel::db()->query($requete)->fetchAll(PDO::FETCH_ASSOC);
216
            if ($infos === false) {
217
                $this->messages[] = "La requête suivante n'a retourné aucun résultat :\n$requete";
218
            }
219
        } catch (PDOException $e) {
220
            $msgTpl = 'Requête echec. Fichier : "%s". Ligne : "%s". Message : %s';
221
            $this->messages[] = sprintf($msgTpl, $e->getFile(), $e->getLine(), $e->getMessage());
222
        }
223
        return $infos;
224
    }
225
 
226
    private function executerService($elements) {
227
        // Prétraitement des données
228
        $donnees = $this->construireDonneesCommunesAuFlux($elements);
229
        foreach ($elements as $element) {
230
            $identifiants[$element['courriel_utilisateur']] = $element['courriel_utilisateur'];
231
        }
232
        $this->auteurs = $this->creerAuteurs($identifiants);
233
 
234
        foreach ($elements as $element) {
235
            $donnees['items'][] = $this->construireDonneesCommunesAuxItems($element);
236
        }
237
 
238
        // Création du contenu à partir d'un template PHP
239
        $contenu = Cel::traiterSquelettePhp($this->squelette, $donnees);
240
 
1499 aurelien 241
        return $contenu;
3743 delphine 242
    }
243
 
244
    private function construireDonneesCommunesAuFlux($infos) {
245
        $donnees = $this->getFlux($this->service);
246
        $donnees['guid'] = $this->getUrlServiceBase();
247
        $donnees['lien_service'] = $this->creerUrlService();
248
        $donnees['lien_cel'] = (isset($infos['nom_sel_nn']) && $infos['nom_sel_nn'] != '' && $infos['nom_sel_nn'] != 0) ?
249
        $this->getUrlEflore($infos['nom_referentiel'], $infos['nom_sel_nn']) : '';
250
        $donnees['editeur'] = $this->config['settings']['editeur'];
251
        $derniere_info_en_date = reset($infos);
252
        $date_modification_timestamp = strtotime($derniere_info_en_date['date_creation']);
253
        $donnees['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp);
254
        $donnees['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp);
255
        $donnees['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp);
256
        $donnees['annee_courante'] = date('Y');
257
        $donnees['generateur'] = 'CEL - Jrest - CelSyndicationImage';
258
        $donnees['generateur_version'] = (preg_match('/([0-9]+)/', '$Revision$', $match)) ?  $match[1] : '0';
259
        return $donnees;
260
    }
261
 
262
    private function construireDonneesCommunesAuxItems($info) {
263
        $item = array();
264
        $date_modification_timestamp = $this->convertirDateHeureMysqlEnTimestamp($info['date_creation']);
265
        $item['date_maj_simple'] = strftime('%A %d %B %Y à %H:%M', $date_modification_timestamp);
266
        $item['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp);
267
        $item['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp);
268
        $item['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp);
269
        $item['titre'] = $this->creerTitre($info);
270
        $item['guid'] = $this->creerGuidItem($info);
271
        $item['lien'] = $this->creerLienItem($info);
272
        $item['categorie'] = $this->creerCategorie($item);
273
        $item['description'] = $this->creerDescription(Cel::protegerCaracteresHtmlDansChamps($info), $item);
274
        $item['description_encodee'] = htmlspecialchars($this->creerDescription($info, $item));
275
        $item['modifier_par'] = $this->nettoyerTexte($this->getIntituleAuteur($info['courriel_utilisateur']));
276
        return $item;
277
    }
278
 
279
    private function creerGuidItem($element) {
280
        $guid = $this->getUrlImage($element['id_image']);
281
        return $guid;
282
    }
283
 
284
    private function creerTitre($element) {
285
        $methode = 'creerTitre'.$this->service;
286
        $methode = (method_exists($this, $methode)) ? $methode : 'creerTitreSimple';
287
        $titre = $this->$methode($element);
288
        $titre = $this->nettoyerTexte($titre);
289
        return $titre;
290
    }
291
 
292
    private function creerDescription($donnees, $item) {
293
        $methode = 'creerDescription'.$this->service;
294
        $methode = (method_exists($this, $methode)) ? $methode : 'creerDescriptionComplet';
295
        $description = $this->$methode($donnees, $item);
296
        $description = $this->nettoyerTexte($description);
297
        return $description;
298
    }
299
 
300
    private function creerLienItem($element) {
301
 
302
        if ($this->etreNull($element['id_observation'])) {
303
            // Lien vers image grand format
304
            $lien = $this->getUrlImage($element['id_image'], $this->format_image);
305
        } else {
306
            // Lien vers fiche eFlore onglet Illustration
307
            $lien = $this->getUrlEflore($element['nom_referentiel'], $element['nom_sel_nn'], 'illustration');
308
        }
309
        return $lien;
310
    }
311
 
312
    private function getServiceListeDesFlux() {
313
        return $this->flux;
314
    }
315
 
316
    private function getServiceOpml() {
317
        $donnees = array();
318
        $id = 1;
319
        foreach ($this->flux as $flux_nom => $flux){
320
            $info = array();
321
            $info['type'] = 'atom';
322
            $info['titre'] = $flux['titre'];
323
            $info['texte'] = "CEL - Images - $flux_nom";
324
            $info['description'] = $flux['description'];
325
            $info['url_xml'] = $this->getUrlBase().$flux_nom.'/atom';
326
            $info['url_html'] = $this->config['settings']['aideCelUrl'].'FluxSyndication';
327
            $donnees['liste_flux'][] = $info;
328
        }
329
 
330
        $this->squelette = $this->squelette_dossier.'opml.tpl.xml';
331
        $contenu = Cel::traiterSquelettePhp($this->squelette, $donnees);
332
        return $contenu;
333
    }
334
 
335
    private function getServiceSimple() {
336
        if (isset($this->parametres[0])) {
337
            $this->format_image = $this->parametres[0];
338
        }
339
 
340
        // Construction de la requête
341
        $requete = 	(isset($this->distinct) ? 'SELECT DISTINCT' : 'SELECT').' co.*, '.
342
            ' ci.id_image, co.ce_utilisateur, nom_original, ci.date_creation, ci.mots_cles_texte AS mots_cles_texte_images, '.
343
            ' co.mots_cles_texte AS mots_cles_texte_images_obs, "" as commentaire, "" as note_qualite, nom_referentiel '.
344
            'FROM cel_export_total AS co JOIN cel_images_export AS ci ON (co.id_observation = ci.ce_observation) '.
345
            'WHERE co.transmission = 1 '.
346
            '	AND co.ce_utilisateur = ci.ce_utilisateur '.
347
            'ORDER BY '.(isset($this->orderby) && (!is_null($this->orderby)) ? $this->orderby  : 'ci.date_creation DESC').' '.
348
            "LIMIT $this->start, $this->limit ";
349
 
350
        $elements = $this->executerRequete($requete);
351
 
352
        // Création du contenu
353
        $contenu = $this->executerService($elements);
354
        return $contenu;
355
    }
356
 
357
    private function creerTitreSimple($element) {
358
        $date = $element['date_observation'];
359
        $date = date("d/m/Y", strtotime($date));
360
        if ($this->etreNull($element['nom_sel']) && $this->etreNull($element['nom_sel_nn'])) {
361
            $titre = "Ajout d'une photo par ".$this->getIntituleAuteur($element['courriel_utilisateur']).' le '.$date;
362
        } else {
363
            $titre = $element['nom_sel'].' [nn'.$element['nom_sel_nn'].'] par '.$this->getIntituleAuteur($element['courriel_utilisateur']).' le '.$date;
364
        }
365
        $zoneGeo = $element['zone_geo'];
366
        if ($zoneGeo) {
367
            $titre .= " - $zoneGeo";
368
        }
369
        return $titre;
370
    }
371
 
372
    private function creerDescriptionSimple($donnees, $item) {
373
        $description = $this->getUrlEflore($element['nom_referentiel'], $element['nom_sel_nn'], 'illustration');
374
        return $description;
375
    }
376
 
377
    private function getServiceComplet() {
378
 
379
        // Construction de la requête
380
        $requete = 	(isset($this->distinct) ? 'SELECT DISTINCT' : 'SELECT').' co.*, '.
381
            '	ci.id_image, co.ce_utilisateur, nom_original, ci.date_creation, ci.mots_cles_texte AS mots_cles_texte_images, '.
382
            '	co.mots_cles_texte AS mots_cles_texte_obs, ci.commentaire AS commentaire_img, note_qualite, nom_referentiel, '.
383
            '	co.commentaire AS commentaire_obs '.
384
            'FROM cel_images_export AS ci '.
385
            '	JOIN cel_export AS co '.
386
            '		ON (ci.ce_observation = co.id_observation) '.
387
            (($this->etreFluxAdmin()) ? '' : 'WHERE co.transmission = 1 ').
388
            'ORDER BY '.(isset($this->orderby) && (!is_null($this->orderby)) ? $this->orderby  : 'ci.date_creation DESC').' '.
389
            "LIMIT $this->start, $this->limit ";
390
            //echo $requete;
391
            $elements = $this->executerRequete($requete);
392
 
393
            // Création du contenu
394
            if ($elements != false && count($elements) > 0) {
395
                $contenu = $this->executerService($elements);
396
            } else {
397
                // ne pas faire ça, car ça déclenche une erreur 500 à tort !
398
                //$this->messages[] = "Aucune image disponible.";
399
                $contenu = array();
400
            }
401
 
402
            return $contenu;
403
    }
404
 
405
    private function getServiceMultiCriteres() {
406
        $contenu = '';
3776 killian 407
        if (isset($_GET['debut'])) $this->start = Cel::db()->proteger($_GET['debut']);
408
        if (isset($_GET['limite'])) $this->limit = Cel::db()->proteger($_GET['limite']);
3743 delphine 409
 
410
        $this->limit = ($this->limit < 1000) ? $this->limit : 1000;// Pour éviter les abus !
411
 
412
        if ($this->parametresSontDemandes()) {
413
            $requete = $this->creerRequeteAvecParametres();
414
        } else {
415
            $requete = $this->creerRequeteSansParametres();
416
        }
417
        $elements = $this->executerRequete($requete);
418
 
419
        // Création du contenu
420
        if ($elements != false && count($elements) > 0) {
421
            $contenu = $this->executerService($elements);
422
        } else {
423
            // ne pas faire ça, car ça déclenche une erreur 500 à tort !
424
            //$this->messages[] = "Aucune image disponible.";
425
        }
426
 
427
        return $contenu;
428
    }
429
 
430
    private function parametresSontDemandes() {
431
        $criteres = $this->traiterCriteresMultiples($_GET) ;
432
        return (isset($_GET['recherche']) && $_GET['recherche'] != '') || !empty($criteres);
433
    }
434
 
435
    private function creerRequeteSansParametres() {
436
        // Construction de la requête
437
        $requete = 'SELECT *, b.mots_cles_texte AS mots_cles_texte_obs, c.mots_cles_texte AS mots_cles_texte_images, '.
438
            ' b.commentaire AS commentaire_obs, "" AS commentaire_img, nom_referentiel '.
439
            'FROM cel_images_export c '.
440
            '	JOIN cel_export AS b '.
441
            '		ON (c.ce_observation = b.id_observation) ';
442
        $requete .= ' ORDER BY '.(isset($this->orderby) && (!is_null($this->orderby)) ? $this->orderby  : 'c.date_creation DESC').' '.
443
            "LIMIT $this->start,$this->limit ";
444
        //echo $requete;
445
        return $requete;
446
    }
447
 
448
    private function creerRequeteAvecParametres() {
449
        // Construction de la requête
450
        $requete = 'SELECT *, b.mots_cles_texte as mots_cles_texte_obs, c.mots_cles_texte as mots_cles_texte_images, '.
451
            ' b.commentaire as commentaire_obs, "" as commentaire_img, nom_referentiel '.
452
            'FROM cel_images_export AS c '.
453
            '	JOIN cel_export_total AS b '.
454
            '		ON (c.ce_observation = b.id_observation) '.
455
            'WHERE '.
456
            (($this->etreFluxAdmin()) ? '' : ' b.transmission = 1 ').
457
            '	AND ';
458
 
459
            if ($this->estUneRechercheGenerale()) {
460
                $chaine_requete = $_GET['recherche'];
461
                $requete .= "donnees_standard =  1 AND ".$this->creerSousRequeteRechercheGenerale($chaine_requete);
462
            } else {
463
                $criteres = $this->traiterCriteresMultiples($_GET) ;
464
                if (!isset($_GET["standard"])) {
465
                    $requete .= "donnees_standard =  1 AND ";
3937 delphine 466
                } elseif ($_GET["standard"] == 1) {
3743 delphine 467
                    $requete .= "donnees_standard =  1 AND ";
3934 delphine 468
                } else {
3936 delphine 469
                    $requete .= "";
3743 delphine 470
                }
471
                if (!empty($criteres)) {
472
                    $requete .= $this->creerSousRequeteRechercheParCriteres($criteres);
473
                }
474
            }
475
            $requete = str_replace(' AND ) ',' ', $requete);
476
            $requete = rtrim($requete, 'AND ');
477
            $requete .= ' ORDER BY '.(isset($this->orderby) && (!is_null($this->orderby)) ? $this->orderby  :
478
                'c.date_creation DESC').' '."LIMIT $this->start,$this->limit ";
479
            return $requete;
480
    }
481
 
482
    private function creerSousRequeteRechercheParCriteres($criteres) {
483
        $requete = '';
484
        foreach ($criteres as $pair) {
485
            $nom_valeur = explode("=",$pair);
486
            if (sizeof($nom_valeur) != 0) {
487
                switch ($nom_valeur[0]) {
488
                    case "ci_limite" : $this->limit = Cel::db()->quote($nom_valeur[1]); break;
489
                    case "c.ci_numero_page" : $this->limit*Cel::db()->quote($nom_valeur[1]); break;
490
                    case "c.commentaire" : $mots_comment_liste = explode(" " , $nom_valeur[1]);
491
                    foreach($mots_comment_liste as $mot_comment) {
492
                        $mot_comment = trim($mot_comment) ;
493
                        $requete .= $nom_valeur[0].' LIKE '.Cel::db()->quote('%'.$mot_comment.'%').' AND ';
494
                    }
495
                    break;
496
                    case "c.date_prise_de_vue" :
497
                        $nom_valeur[1] = str_replace('/', '-', $nom_valeur[1]);
498
                        if (preg_match('/(^[0-9]{2})-([0-9]{2})-([0-9]{4}$)/', $nom_valeur[1], $matches)) {
499
                            $nom_valeur[1] = $matches[3].'-'.$matches[2].'-'.$matches[1];
500
                        }
501
                        $requete .= $nom_valeur[0].' LIKE '.Cel::db()->quote($nom_valeur[1]."%").' AND '; break;
502
                    case "b.ce_zone_geo" :
503
                        $requete .= ' ('.$nom_valeur[0].' LIKE "%'.$nom_valeur[1].'%") AND '; break;
504
                    case "b.nom_ret" :
505
                        if ($nom_valeur[1] == "indetermine") $nom_valeur[1] = 'null';
506
                        $requete .= ' ('.$nom_valeur[0].' LIKE "%'.$nom_valeur[1].'%" OR b.nom_sel LIKE "%'.
507
                            $nom_valeur[1].'%") AND '; break;
508
                    case "tag" : $requete .= $this->creerSousRequeteMotsCles($nom_valeur[1]).' AND '; break;
509
                    case "projet" : $requete .= $this->creerSousRequeteProjet($nom_valeur[1]).' AND '; break;
510
                    case "referentiel" : $requete .= $this->creerSousRequeteReferentiel($nom_valeur[1]).' AND '; break;
511
                    case "groupe_zones_geo" : $requete .= $this->creerSousRequeteGroupeZonesGeo($nom_valeur[1])." AND "; break;
512
                    default : $requete .= $nom_valeur[0].' = "'.$nom_valeur[1].'" AND '; break;
513
                }
514
            }
515
        }
516
        $requete = rtrim($requete,' AND ');
517
        return $requete;
518
    }
519
 
520
    private function creerSousRequeteGroupeZonesGeo($groupe_zones_geo) {
521
        $req = "SELECT valeur FROM cel_groupes_zones WHERE id_groupe = ".Cel::db()->proteger($groupe_zones_geo);
522
        $res = Cel::db()->requeter($req);
523
        $zones = array();
524
        foreach($res as &$r) {
525
            $zones[] = Cel::db()->proteger($r['valeur']);
526
        }
527
        $sql = '(b.ce_zone_geo IN ('.implode(',', $zones).')) ';
528
 
529
        return $sql;
530
    }
531
 
532
    private function creerSousRequeteMotsCles($mot_cle) {
533
        $requete = '';
534
        if (preg_match('/.*OU.*/', $mot_cle)) {
535
            $mots_cles_tab = explode('OU',$mot_cle);
536
            foreach($mots_cles_tab as $mot_cle_item) {
537
                $requete .= '(c.mots_cles_texte LIKE '.Cel::db()->proteger('%'.$mot_cle_item.'%').') OR ';
538
            }
539
            $requete = '('.rtrim($requete,'OR ').')';
540
        } else if (preg_match('/.*ET.*/', $mot_cle)) {
541
            $mots_cles_tab = explode('ET',$mot_cle);
542
            foreach($mots_cles_tab as $mot_cle_item) {
543
                $requete .= '(c.mots_cles_texte LIKE '.Cel::db()->proteger('%'.$mot_cle_item.'%').') AND ';
544
            }
545
            $requete = '('.rtrim($requete, 'AND ').') ';
546
        } else {
547
            $requete = "(c.mots_cles_texte LIKE ".Cel::db()->proteger('%'.$mot_cle.'%').') ';
548
        }
549
        return $requete;
550
    }
551
 
552
    private function creerSousRequeteProjet($mot_cle) {
553
        $requete = '';
554
        if (preg_match('/.*OU.*/', $mot_cle)) {
555
            $mots_cles_tab = explode('OU',$mot_cle);
556
            foreach($mots_cles_tab as $mot_cle_item) {
557
                $requete .= '(b.mots_cles_texte LIKE '.Cel::db()->proteger('%'.$mot_cle_item.'%').') OR ';
558
            }
559
            $requete = '('.rtrim($requete,'OR ').')';
560
        } else if (preg_match('/.*ET.*/', $mot_cle)) {
561
            $mots_cles_tab = explode('ET',$mot_cle);
562
            foreach($mots_cles_tab as $mot_cle_item) {
563
                $requete .= '(b.mots_cles_texte LIKE '.Cel::db()->proteger('%'.$mot_cle_item.'%').') AND ';
564
            }
565
            $requete = '('.rtrim($requete, 'AND ').') ';
566
        } else {
567
            $requete = "(b.mots_cles_texte LIKE ".Cel::db()->proteger('%'.$mot_cle.'%').') ';
568
        }
569
        return $requete;
570
    }
571
 
572
    private function creerSousRequeteReferentiel($referentiel) {
573
        $requete = "b.nom_referentiel LIKE '$referentiel%'";
574
        return $requete;
575
    }
576
 
577
    private function creerSousRequeteRechercheGenerale($chaine_requete) {
578
        $requete = '';
3791 killian 579
        $chaine_requete = Cel::deb()->proteger($chaine_requete.'%');
3743 delphine 580
        if (trim($chaine_requete) != '') {
581
            $chaine_requete = strtolower($chaine_requete);
582
            $chaine_requete = str_replace(' ', '_', $chaine_requete);
583
            $requete = ' ('.
3791 killian 584
                'b.nom_ret LIKE '.$chaine_requete.
3743 delphine 585
                ' OR '.
3791 killian 586
                'b.nom_sel LIKE '.$chaine_requete.
3743 delphine 587
                ' OR '.
3791 killian 588
                'b.zone_geo LIKE '.$chaine_requete.
3743 delphine 589
                ' OR '.
3791 killian 590
                'b.ce_zone_geo LIKE INSEE-C:'.$chaine_requete.
3743 delphine 591
                ' OR '.
3791 killian 592
                'b.ce_zone_geo LIKE '.$chaine_requete.
3743 delphine 593
                ' OR '.
3791 killian 594
                'b.ce_utilisateur LIKE '.$chaine_requete.
3743 delphine 595
                ' OR '.
3791 killian 596
                'b.courriel_utilisateur LIKE '.$chaine_requete.
3743 delphine 597
                ' OR '.
3791 killian 598
                'b.mots_cles_texte LIKE '.$chaine_requete.
3743 delphine 599
                ') ';
600
        }
601
        return $requete;
602
    }
603
 
604
    private function estUneRechercheGenerale() {
605
        return isset($_GET['recherche']);
606
    }
607
 
608
    private function traiterCriteresMultiples($tableau_criteres) {
609
        $tableau_criteres_pour_bdd = array();
610
 
611
        foreach($tableau_criteres as $nom_critere => $valeur_critere) {
612
            if (isset($this->criteres[$nom_critere])) {
3794 delphine 613
                //$valeur_critere = Cel::db()->proteger($valeur_critere);
3743 delphine 614
                $tableau_criteres_pour_bdd[] = $this->criteres[$nom_critere].'='.$valeur_critere;
615
            }
616
        }
617
        return $tableau_criteres_pour_bdd;
618
    }
619
 
620
    private function creerDescriptionComplet($donnees, $item) {
621
        $auteur = $this->getIntituleAuteur($donnees['courriel_utilisateur']);
622
        $auteur_mail = $donnees['courriel_utilisateur'];
623
 
624
        $id_img = $donnees['id_image'];
625
        $nom_fichier = $donnees['nom_original'];
626
        $url_img = $this->getUrlImage($donnees['id_image'], 'CS');
627
        $url_img_normale = $this->getUrlImage($donnees['id_image'], 'XL');
628
        //
629
        $mots_cles_image = $donnees['mots_cles_texte_images'];
630
        $note = ($donnees['note_qualite'] +1).'/5';
631
        $commentaire_img = $donnees['commentaire_img'];
632
 
633
        $id_obs = $donnees['id_observation'];
634
        $famille = $donnees['famille'];
635
        $nom_saisi = $donnees['nom_sel'];
636
        $nom_retenu = $donnees['nom_ret'];
637
        //
638
        $mots_cles_obs = $donnees['mots_cles_texte_obs'];
639
 
640
        $lieu =  $this->formaterZoneGeoEtCodePourAffichage($donnees).' > '.$donnees['lieudit'].' > '.$donnees['station'];
641
        $milieu = $donnees['milieu'];
642
        $coordonnees = ($this->etreNull($donnees['latitude']) && $this->etreNull($donnees['longitude'])) ? '' : $donnees['latitude'].'/'.$donnees['longitude'];
643
        $commentaire_obs = $donnees['commentaire_obs'];
644
        $date_observation = $this->formaterDate($donnees['date_observation'], '%A %d %B %Y');
645
        $date_transmission = $this->formaterDate($donnees['date_transmission']);
646
        $date_modification = $this->formaterDate($donnees['date_modification']);
647
        $date_creation = $this->formaterDate($donnees['date_creation']);
648
        $transmission = $donnees['transmission'] == 1 ? "oui ($date_transmission)" : 'non';
649
 
650
        $description = '<style>.champ{color:grey} .gauche{float:left;padding:0 20px 0 0;} ul{list-style-type:none;padding:0;}</style>'.
651
            '<h2>'.(!$this->etreNull($id_obs) ? "Image #$id_img liée à l'observation #$id_obs" : "Image #$id_img non liée à une observation.").'</h2>'.
652
            '<a href="'.$url_img_normale.'"><img class="gauche" src="'.$url_img.'" alt="'.$nom_fichier.'" /></a>'.
653
            '<div class="gauche">'.
654
            '<h3>'.'Image'.'</h3>'.
655
            '<ul>'.
656
            '<li>'.'<span class="champ">URL :</span> <a href="'.$url_img_normale.'.jpg" onclick="javascript:window.open(this.href);return false;">'.$url_img_normale.'</a></li>'.
657
            '<li>'.'<span class="champ">Importée le :</span> '.$item['date_maj_simple'].'</li>'.
658
            '<li>'.'<span class="champ">Par :</span> '.
659
            (($this->etreFluxAdmin()) ? '<a href="mailto:'.$auteur_mail.'">'.$auteur.'</a>' : $auteur).
660
            '</li>'.
661
            '<li>'.'<span class="champ">Nom du fichier :</span> '.$this->nePasInterpreterXml($nom_fichier).'</li>'.
662
            '<li>'.'<span class="champ">Note qualité :</span> '.$note.'</li>'.
663
            '<li>'.'<span class="champ">Commentaires :</span> '.$this->nePasInterpreterXml($commentaire_img).'</li>'.
664
            '<li>'.'<span class="champ">Mots-clés :</span> '.$this->nePasInterpreterXml($mots_cles_image).'</li>'.
665
            '</ul>'.
666
            '</div>';
667
            // TODO : ajouter le champ commentaire EXIF.
668
            if (! $this->etreNull($id_obs)) {
669
                $description .=
670
                '<div class="gauche">'.
671
                '<h3>'.'Observation'.'</h3>'.
672
                '<ul>'.
673
                '<li>'.'<span class="champ">Famille :</span> '.$famille.'</li>'.
674
                '<li>'.'<span class="champ">Nom saisi :</span> '.$nom_saisi.'</li>'.
675
                '<li>'.'<span class="champ">Nom retenu :</span> '.$nom_retenu.'</li>'.
676
                '<li>'.'<span class="champ">Observée le :</span> '.$date_observation.'</li>'.
677
                '<li>'.'<span class="champ">Lieu :</span> '.$lieu.'</li>'.
678
                '<li>'.'<span class="champ">Milieu :</span> '.$milieu.'</li>'.
679
                (($this->etreFluxAdmin()) ? '<li><span class="champ">Coordonnées (Lat/Long) :</span> '.$coordonnees.'</li>' : '').
680
                '<li>'.'<span class="champ">Commentaire :</span> '.$this->nePasInterpreterXml($commentaire_obs).'</li>'.
681
                '<li>'.'<span class="champ">Mots-clés :</span> '.$this->nePasInterpreterXml($mots_cles_obs).'</li>'.
682
                (($this->etreFluxAdmin()) ? '<li><span class="champ">Transmis (= public) :</span> '.$transmission.'</li>' : '').
683
                '<li><span class="champ">Modifiée le :</span> '.$date_modification.'</li>'.
684
                '<li><span class="champ">Créée le :</span> '.$date_creation.'</li>'.
685
                '</ul>'.
686
                '</div>';
687
            }
688
            $description = $this->nettoyerTexte($description);
689
            return $description;
690
    }
691
 
692
    private function getServiceParMotsCles() {
693
        $infos=array();
694
        $infos[0]['nom_sel_nn'] = '';
695
        $infos[0]['date_creation'] = '2011-06-28';
696
        $donnees = $this->construireDonneesCommunesAuFlux($infos);
697
        $donnees['items'][0]['guid'] = 0;
698
        $donnees['items'][0]['description'] =  'Ce flux est devenu obsolète. Veuillez utiliser le flux '.
699
            '<b>http://www.tela-botanica.org/eflore/cel2/jrest/CelSyndicationImage/multicriteres/atom?tag=';
700
        if (isset($this->parametres[0])) {
701
            $donnees['items'][0]['description'] .= $this->parametres[0].'</b>';
702
        } else {
703
            $donnees['items'][0]['description'] .= '</b>';
704
        }
705
        $donnees['items'][0]['titre'] = '';
706
        $contenu = Cel::traiterSquelettePhp($this->squelette, $donnees);
707
        return $contenu;
708
    }
709
 
710
    private function getServiceParCommune() {
711
        $infos=array();
712
        $infos[0]['nom_sel_nn'] = '';
713
        $infos[0]['date_creation'] = '2011-06-28';
714
        $donnees = $this->construireDonneesCommunesAuFlux($infos);
715
        $donnees['items'][0]['guid'] = 0;
716
        $donnees['items'][0]['description'] = 'Ce flux est devenu obsolète. Veuillez utiliser le flux '.
717
            '<b>http://www.tela-botanica.org/eflore/cel2/jrest/CelSyndicationImage/multicriteres/atom?commune=';
718
        if (isset($this->parametres[0])) {
719
            $donnees['items'][0]['description'] .= $this->parametres[0].'</b>';
720
        } else {
721
            $donnees['items'][0]['description'] .= '</b>';
722
        }
723
        $donnees['items'][0]['titre'] = '';
724
        $contenu = Cel::traiterSquelettePhp($this->squelette, $donnees);
725
        return $contenu;
726
    }
727
 
728
    private function getIntituleAuteur($courriel) {
729
        $courriel = strtolower($courriel);
730
        $intitule = $this->auteurs[$courriel];
731
        return $intitule;
732
    }
3033 mathias 733
}