Rev 1284 | Blame | Last modification | View Log | RSS feed
<?php/*** Service fournissant des informations concernant les commentaire de DEL au format RSS1, RSS2 ou ATOM.* Encodage en entrée : utf8* Encodage en sortie : utf8** @author Aurélien PERONNET <aurelien@tela-botanica.org>* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>* @version $Id$* @copyright 2010*/class SyndicationCommentaires {private $ressources = null;private $parametres = null;private $format = null;private $service = null;private $squelette = null;private $squelette_dossier = null;private $masque = array();private $mappingFiltre = array();private $conteneur = null;private $gestionBdd = null;private $navigation = null;public function __construct(Conteneur $conteneur = null) {$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;$this->conteneur->chargerConfiguration('config_syndication_commentaires.ini');$this->mappingFiltre = $this->conteneur->getParametre('mapping_masque');$this->masque = $conteneur->getMasque();$this->gestionBdd = $conteneur->getGestionBdd();$this->navigation = $conteneur->getNavigation();}public function consulter($params = array()) {$this->verifierConfiguration();if ($this->fluxAdminDemande()) {$this->demanderAutorisationAdmin();}$donnees_brutes = $this->getDerniersCommentaires();$commentaires_formates = $this->formaterPourRss($donnees_brutes) ;return $commentaires_formates;}/*** Vérifier que le service est bien configuré* */public function verifierConfiguration() {$erreurs = array();$tableauImages = $this->conteneur->getParametre('mapping_masque');if (empty($this->mappingFiltre)) {$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;';} else {$champsMappingFiltre = array('espece', 'observation');foreach ($champsMappingFiltre as $champ) {if (!isset($this->mappingFiltre[$champ])) {$erreurs[] = '- le mapping du champ "'.$champ.'" pour le commentaire est manquant ;';}}}if (!empty($erreurs)) {$e = 'Erreur lors de la configuration : '."\n";$e .= implode("\n", $erreurs);throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);}}/*** Verifier si le flux admin est demande*/private function fluxAdminDemande() {return $this->conteneur->getParametre('admin') != null && $this->conteneur->getParametre('admin') == 1;}private function demanderAutorisationAdmin() {$verification = new ControleAcces($this->conteneur);$verification->demanderAuthentificationAdmin();}private function formaterPourRss($elements) {$donnees = $this->construireDonneesCommunesAuFlux($elements);foreach ($elements as $element) {$identifiants[$element['id_commentaire']] = $element['id_commentaire'];}foreach ($elements as $element) {$donnees['items'][] = $this->construireDonneesCommunesAuxItems($element);}return $donnees;}private function creerCategorie($element) {$categorie = 'Commentaires';$categorie = htmlentities($categorie);return $categorie;}private function creerUrlService() {$url_service = '';if (count($_GET) > 0) {$parametres_get = array();foreach ($_GET as $cle => $valeur) {$parametres_get[] = $cle.'='.$valeur;}$url_service .= '?'.implode('&', $parametres_get);}return $url_service;}private function construireDonneesCommunesAuFlux($infos) {$donnees = array();$donnees['guid'] = '';$donnees['titre'] = 'identiPlante : commentaires et propositions';$donnees['description'] = 'Ce flux regroupe les dernières déterminations et commentaires rédigés dans l\'application identiPlante';$donnees['lien_service'] = $this->creerUrlService();$donnees['lien_del'] = $this->conteneur->getParametre('delAppliLien');$donnees['editeur'] = $this->conteneur->getParametre('editeur');$derniere_info_en_date = reset($infos);$date_modification_timestamp = strtotime($derniere_info_en_date['date']);$donnees['date_maj_RSS'] = date(DATE_RSS, $date_modification_timestamp);$donnees['date_maj_ATOM'] = date(DATE_ATOM, $date_modification_timestamp);$donnees['date_maj_W3C'] = date(DATE_W3C, $date_modification_timestamp);$donnees['annee_courante'] = date('Y');$donnees['generateur'] = 'DEL - SyndicationCommentaire';$donnees['generateur_version'] = (preg_match('/([0-9]+)/', '$Revision$', $match)) ? $match[1] : '0';return $donnees;}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'] = $this->creerCategorie($item);$item['description'] = $this->creerDescription($info, $item);$item['description_encodee'] = htmlspecialchars($this->creerDescription($info, $item));$item['modifie_par'] = $this->creerAuteur($info);return $item;}private function creerGuidItem($element) {$guid = sprintf($this->conteneur->getParametre('guidObsTpl'), $element['id_commentaire']);return $guid;}private function creerLienItem($element) {$lien = sprintf($this->conteneur->getParametre('delFicheObsTpl'), $element['dob_id_observation']);return $lien;}private function creerTitre($element) {$intitule = ($element['nom_sel'] != '') ? 'Proposition' : 'Commentaire';$titre = $intitule.' - Observation '.$element['dob_id_observation'].' - '.htmlspecialchars($element['dob_nom_sel']).' à '.$element['dob_zone_geo'].' le '.$element['dob_date_observation'];return $titre;}private function creerDescription($donnees, $item) {$nomSel = ($donnees['nom_sel'] != '') ? htmlspecialchars($donnees['nom_sel']) : '';$txt = ($donnees['texte'] != '') ? htmlspecialchars($donnees['texte']) : '';$etreProposition = ($nomSel != '') ? true : false;$auteur = htmlspecialchars($this->creerAuteur($donnees)).($this->fluxAdminDemande() ? ' ('.$donnees['utilisateur_courriel'].')' : '');$contenu = '';if ($etreProposition) {$contenu = "<li>Proposition : <em>$nomSel</em></li>".((!empty($txt)) ? "<li>Argumentaire : $txt</li>" : '');"<li>Auteur de la proposition : $auteur</li>";} else {$contenu = "<li>Commentaire : <pre>$txt</pre></li>"."<li>Auteur du commentaire : $auteur</li>";}$description = "<ul>$contenu</ul>";return $description;}private function creerAuteur($info) {return $info['utilisateur_prenom'].' '.$info['utilisateur_nom'];}private function getDerniersCommentaires() {$requete = 'SELECT DISTINCT dc.*, '.' dob.id_observation AS dob_id_observation, dob.ce_zone_geo AS dob_ce_zone_geo, '.' dob.zone_geo AS dob_zone_geo, dob.date_observation AS dob_date_observation, dob.nom_sel AS dob_nom_sel '.'FROM del_commentaire AS dc '.' INNER JOIN del_observation AS dob '.' ON dob.id_observation = dc.ce_observation '.'WHERE ((dob.ce_utilisateur = dc.ce_utilisateur AND dob.nom_sel != dc.nom_sel) '.' OR (dob.ce_utilisateur != dc.ce_utilisateur)) '.$this->chargerClauseWhere().' '.'ORDER BY dc.date DESC '.'LIMIT '.$this->navigation->getDepart().','.$this->navigation->getLimite().' ';$elements = $this->gestionBdd->getBdd()->recupererTous($requete);return $elements;}/*** Charger la clause WHERE en fonction des paramètres de masque* */private function chargerClauseWhere() {$where = array();$tableauMasque = $this->masque->getMasque();if (!empty($tableauMasque)) {foreach($tableauMasque as $idMasque => $valeurMasque) {$idMasque = str_replace('masque.', '', $idMasque);switch ($idMasque) {case 'espece':$where[] = ' dob.'.$this->mappingFiltre[$idMasque].' LIKE '.$this->gestionBdd->getBdd()->proteger($valeurMasque.'%').' '.' OR '.' dc.'.$this->mappingFiltre[$idMasque].' LIKE '.$this->gestionBdd->getBdd()->proteger($valeurMasque.'%').' ';break;case 'auteur':$where[] = $this->creerFiltreAuteur($valeurMasque).' ';break;default:$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->gestionBdd->getBdd()->proteger($valeurMasque);}}}if (!empty($where)) {return ' AND '.implode('AND', $where);} else {return;}}private function creerFiltreAuteur($auteurId) {$masque = '';if (is_numeric($auteurId)) {$masque = " dc.ce_utilisateur = $auteurId ";} else {$auteurIdMotif = $this->gestionBdd->getBdd()->proteger($auteurId.'%');if (strpos($auteurId, '@') === false) {$tableauNomPrenom = explode(' ', $auteurId, 2);if (count($tableauNomPrenom) == 2) {// on teste potentiellement un nom prenom ou bien un prénom nom$nomMotif = $this->gestionBdd->getBdd()->proteger($tableauNomPrenom[0].'%');$prenomMotif = $this->gestionBdd->getBdd()->proteger($tableauNomPrenom[1].'%');$masque = '('."(dc.utilisateur_nom LIKE $nomMotif AND dc.utilisateur_prenom LIKE $prenomMotif) ".'OR '."(dc.utilisateur_nom LIKE $nomMotif AND dc.utilisateur_prenom LIKE $prenomMotif) ".')';} else {$masque = "(dc.utilisateur_nom LIKE $auteurIdMotif OR dc.utilisateur_prenom LIKE $auteurIdMotif) ";}} else {$masque = " dob.utilisateur_courriel LIKE $auteurIdMotif ";}}return $masque;}}?>