* @author Jean-Pascal MILCENT * @author Aurelien PERONNET * @license GPL v3 * @license CECILL v2 * @copyright 1999-2014 Tela Botanica */ class Tags { private $categorie = 'Tag'; private $conteneur; private $bdd; private $navigation; private $syndication; private $mapping = array(); public function __construct(Conteneur $conteneur) { $this->conteneur = $conteneur; $this->bdd = $this->conteneur->getBdd(); $this->navigation = $this->conteneur->getNavigation(); $this->syndication = $this->conteneur->getSyndicationOutils(); $this->mapping = $this->conteneur->getParametreTableau('syndication.mapping'); } public function consulter() { if ($this->syndication->fluxAdminDemande()) { $this->syndication->demanderAutorisationAdmin(); } $donnees_brutes = $this->getDerniersVotesImage(); $commentaires_formates = $this->formaterPourRss($donnees_brutes) ; return $commentaires_formates; } /** * Formater les données pour mettre en page le RSS * */ private function formaterPourRss($elements) { $derniere_info_en_date = reset($elements); $donnees = $this->syndication->construireDonneesCommunesAuFlux('tag', $derniere_info_en_date['date']); foreach ($elements as $element) { $donnees['items'][] = $this->construireDonneesCommunesAuxItems($element); } return $donnees; } /** * Générer les données communes & spécifiques à chaque item * */ private function construireDonneesCommunesAuxItems($info) { $item = array(); $date_modification_timestamp = strtotime($info['date']); $item['date_maj_simple'] = strftime('%A %d %B %Y à %H:%M', $date_modification_timestamp); $item['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp); $item['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp); $item['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp); $item['titre'] = $this->creerTitre($info); $item['guid'] = $this->creerGuidItem($info); $item['lien'] = $this->creerLienItem($info); $item['categorie'] = htmlentities($this->categorie); $item['description'] = $this->creerDescription($info, $item); $item['description_encodee'] = htmlspecialchars($this->creerDescription($info, $item)); $item['modifier_par'] = $this->formaterNomTagueur($info); return $item; } private function creerGuidItem($element) { $guid = sprintf($this->conteneur->getParametre('syndication.tag_guid_tpl'), $element['id_tag']); return $guid; } private function creerLienItem($element) { // TODO : ajouter un lien vers la plateforme validation de picto lorsqu'elle sera dispo $lien = sprintf($this->conteneur->getParametre('img_fiche_tpl'), $element['id_image']); return $lien; } private function creerTitre($element) { $tag = $element['tag']; $nomSel = htmlspecialchars($element['nom_sel']); $tagueur = htmlspecialchars($this->formaterNomTagueur($element)); $auteurImg = $this->formaterNomAuteurImg($element); $titre = "Tag «{$tag}» par $tagueur pour $nomSel de $auteurImg"; return $titre; } private function creerDescription($donnees, $item) { $idTag = htmlspecialchars($donnees['id_tag']); $idObs = htmlspecialchars($donnees['id_observation']); $idImg = htmlspecialchars($donnees['id_image']); $urlImg = $this->syndication->getUrlImage($donnees['id_image']); $miniatureUrl = $this->syndication->getUrlImage($donnees['id_image'], 'CRS'); $nomSelActuel = htmlspecialchars($donnees['nom_sel']); $dateObs = htmlspecialchars(str_replace(' 00:00:00', '', $donnees['date_observation'])); $lieuObs = htmlspecialchars($donnees['zone_geo']); $tag = htmlspecialchars($donnees['tag']); $dateTag = htmlspecialchars(strftime('%A %d %B %Y à %H:%M', strtotime($donnees['date']))); $auteurImg = htmlspecialchars($this->creerAuteurImg($donnees)); $tagueur = htmlspecialchars($this->creerTagueur($donnees)); $description = ''. '

'."Tag pictoFlora #$idTag pour l'image #$idImg de l'observation #$idObs".'

'. '
'. ' '. ' Img #'.$idImg.''. ' '. '
'. '
'. "

Image #$idImg de l'observation #$idObs

". '
    '. '
  • '."Auteur de l'image : $auteurImg
  • ". '
  • '."Nom saisi actuel : $nomSelActuel
  • ". '
  • '."Lieu : $lieuObs
  • ". '
  • '."Date : $dateObs
  • ". '
'. '
'. '
'. "

Tag #$idTag

". '
    '. '
  • '."Tag : $tag
  • ". '
  • '."Auteur : $tagueur
  • ". '
  • '."Taguée le : $dateTag
  • ". '
'. '
'; return $description; } private function creerAuteurImg($info) { $auteur = $this->formaterNomAuteurImg($info). ($this->syndication->fluxAdminDemande() ? ' ('.$info['auteur_courriel'].')' : ''); return $auteur; } private function formaterNomAuteurImg($info) { $auteur = 'Anonyme'; if ($info['auteur_prenom'] != '' && $info['auteur_nom'] != '') { $auteur = $info['auteur_prenom'].' '.$info['auteur_nom']; } return $auteur; } private function creerTagueur($info) { $tagueur = $this->formaterNomTagueur($info). ($this->syndication->fluxAdminDemande() ? ' ('.$info['tagueur_courriel'].')' : ''); return $tagueur; } private function formaterNomTagueur($info) { $tagueur = 'Anonyme'; if ($info['tagueur_prenom'] != '' && $info['tagueur_nom'] != '') { $tagueur = $info['tagueur_prenom'].' '.$info['tagueur_nom']; } return $tagueur; } /** * Retrouver les derniers votes image * */ private function getDerniersVotesImage() { $elements = array(); $idsTags = $this->getIdsDerniersVotesImage(); if (!empty($idsTags)) { $idsTagsConcat = implode(', ', $idsTags); $requete = 'SELECT DISTINCT id_tag, tag, date, '. ' do.id_observation, do.nom_sel, do.zone_geo, do.date_observation, di.id_image, '. ' duo.prenom AS auteur_prenom, duo.nom AS auteur_nom, duo.courriel AS auteur_courriel, '. ' du.prenom AS tagueur_prenom, du.nom AS tagueur_nom, du.courriel AS tagueur_courriel '. 'FROM del_image_tag AS dit '. ' INNER JOIN del_image AS di '. ' ON ce_image = id_image '. ' INNER JOIN del_observation AS do '. ' ON di.ce_observation = do.id_observation '. ' LEFT JOIN del_utilisateur AS duo '. ' ON do.ce_utilisateur = duo.id_utilisateur '. ' LEFT JOIN del_utilisateur AS du '. ' ON if((CHAR_LENGTH(dit.ce_utilisateur) <> 32),CAST(dit.ce_utilisateur AS unsigned),0) '. ' = du.id_utilisateur '. 'WHERE actif = 1 '. " AND id_tag IN ($idsTagsConcat) ". 'ORDER BY date DESC '. 'LIMIT '.$this->navigation->getDepart().','.$this->navigation->getLimite().' '. ' -- '.__FILE__.' : '.__LINE__; $elements = $this->bdd->recupererTous($requete); } return $elements; } /** * Retrouver les ids des derniers votes image * */ private function getIdsDerniersVotesImage() { $requete = 'SELECT DISTINCT id_tag '. 'FROM del_image_tag '. 'WHERE actif = 1 '. // Pas de filtre pour ce service. Utiliser le principe des autres ws de syndication si on devait en rajouter. 'ORDER BY date DESC '. 'LIMIT '.$this->navigation->getDepart().','.$this->navigation->getLimite().' '. ' -- '.__FILE__.' : '.__LINE__; $resultats = $this->bdd->recupererTous($requete); $idsTags = array(); if ($resultats != false && is_array($resultats)) { foreach ($resultats as $infos) { $idsTags[] = $infos['id_tag']; } } return $idsTags; } }