26,7 → 26,7 |
private $ressources = array(); |
private $tri = 'date_transmission'; |
private $directionTri = 'desc'; |
|
|
public function __construct(Conteneur $conteneur = null) { |
$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur; |
$this->conteneur->chargerConfiguration('config_departements_bruts.ini'); |
38,11 → 38,10 |
$this->gestionBdd = $conteneur->getGestionBdd(); |
$this->bdd = $this->gestionBdd->getBdd(); |
} |
|
|
|
/** |
* RequeteSansParametres |
* |
* |
* permet de vérifier qu'il n'y a aucun paramètre dans la requete, excepté les informations de start et limite, |
* pour ajuster la requête pour un gain de temps |
* @param array $ressources les ressources telles qu'elles sont passées au script |
50,11 → 49,11 |
* */ |
public function requeteSansParametres($ressources, $parametres) { |
$estSansParametres = true; |
|
|
if (sizeof($ressources) > 0) { |
$estSansParametres = false; |
} |
|
|
if (sizeof($parametres) > 2) { |
// s'il y a plus de 2 paramètres, on est forcément dans le cas où on a demandé des paramètres autre que la navigation |
$estSansParametres = false; |
71,19 → 70,18 |
} |
} |
} |
|
|
return $estSansParametres; |
} |
|
|
/** |
* Méthode principale de la classe. |
* Lance la récupération des images dans la base et les place dans un objet ResultatService |
* Lance la récupération des images dans la base et les place dans un objet ResultatService |
* pour l'afficher. |
* @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2) |
* @param array $parametres les paramètres situés après le ? dans l'url |
* */ |
public function consulter($ressources, $parametres) { |
|
$this->initialiserRessourcesEtParametres($ressources, $parametres); |
$this->configurer(); |
$this->verifierConfiguration(); |
90,8 → 88,8 |
$this->verifierParametresTri(); |
$this->initialiserTri(); |
|
$resultat = new ResultatService(); |
if ($this->requeteSansParametres($ressources, $parametres)) { |
|
$liaisons = $this->chargerLiaisonsSimple(); |
$observations = $this->chargerObservations($liaisons); |
$total = $this->compterObservations(); |
98,7 → 96,7 |
$this->navigation->setTotal($total); |
$observations = $this->chargerImages($observations); |
$observations = $this->chargerDeterminations($observations); |
|
|
//Compute |
$resultats = array(); |
foreach ($observations as $id => $observation) { |
105,37 → 103,29 |
$idObs = $observation['id_observation']; |
$resultats['"'.$idObs.'"'] = $observation; |
} |
|
|
// Mettre en forme le résultat et l'envoyer pour affichage |
$resultat = new ResultatService(); |
$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $resultats); |
|
return $resultat; |
} else { |
|
// Lancement du service |
$liaisons = $this->chargerLiaisons(); |
|
$total = $this->compterObservations(); |
$this->navigation->setTotal($total); |
$observations = $this->chargerObservations($liaisons); |
$observations = $this->chargerImages($observations); |
$observations = $this->chargerDeterminations($observations); |
|
|
// Mettre en forme le résultat et l'envoyer pour affichage |
$resultat = new ResultatService(); |
$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => $observations); |
return $resultat; |
} |
return $resultat; |
} |
|
|
private function initialiserRessourcesEtParametres($ressources, $parametres) { |
$this->ressources = $ressources; |
$this->parametres = $parametres; |
} |
|
|
private function verifierParametresTri() { |
|
$erreurs = array(); |
$tris_possibles = $this->conteneur->getParametre('tris_possibles'); |
$tris_possibles_tableau = explode(',', $tris_possibles); |
142,12 → 132,12 |
if(isset($this->parametres['tri']) && !in_array($this->parametres['tri'], $tris_possibles_tableau)) { |
$erreurs[] = '- le type de tri demandé est incorrect, les valeurs possibles sont '.$tris_possibles.' ;'; |
} |
|
|
$directions_tri = array('asc', 'desc'); |
if(isset($this->parametres['ordre']) && !in_array($this->parametres['ordre'], $directions_tri)) { |
$erreurs[] = '- la direction du tri demandé est incorrecte, les valeurs supportées sont asc ou desc ;'; |
} |
|
|
if (!empty($erreurs)) { |
$e = 'Erreur lors de l\'analyse des parametres du tri : '."\n"; |
$e .= implode("\n", $erreurs); |
154,7 → 144,7 |
throw new Exception($e, RestServeur::HTTP_CODE_ERREUR); |
} |
} |
|
|
private function initialiserTri() { |
$this->tri = isset($this->parametres['tri']) ? $this->parametres['tri'] : $this->tri; |
$this->directionTri = isset($this->parametres['ordre']) ? $this->parametres['ordre'] : $this->directionTri; |
171,44 → 161,44 |
$this->mappingVotes = $this->conteneur->getParametre('mapping_votes'); |
$this->mappingCommentaire = $this->conteneur->getParametre('mapping_commentaire'); |
} |
|
|
/** |
* Vérifier que le service est bien configuré |
* Vérifier que le service est bien configuré |
* */ |
private function verifierConfiguration() { |
|
$erreurs = array(); |
$tableauObservations = $this->conteneur->getParametre('observations'); |
if (empty($tableauObservations)) { |
$erreurs[] = '- le fichier de configuration ne contient pas le tableau [images] ou celui-ci est vide ;'; |
$erreurs[] = '- le fichier de configuration ne contient pas le tableau [images] ou celui-ci est vide ;'; |
} else { |
if ($this->conteneur->getParametre('url_service') == null) { |
$erreurs[] = '- paramètre "url_service" manquant ;'; |
} |
|
|
if ($this->conteneur->getParametre('url_images') == null) { |
$erreurs[] = '- paramètre "url_images" manquant ;'; |
} |
|
} |
|
if (empty($this->mappingObservation)) { |
$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_observation] ou celui-ci est vide ;'; |
} else { |
$champsMappingObs = array('id_observation', 'date_observation', 'date_transmission', 'famille', 'nom_sel', 'nom_sel_nn', 'nt', |
'ce_zone_geo', 'zone_geo', 'lieudit', 'station', 'courriel', 'ce_utilisateur', 'nom', 'prenom'); |
|
$champsMappingObs = array('id_observation', 'date_observation', 'date_transmission', 'famille', |
'nom_sel', 'nom_sel_nn', 'nt', 'ce_zone_geo', 'zone_geo', 'lieudit', 'station', 'courriel', |
'ce_utilisateur', 'nom', 'prenom'); |
|
foreach ($champsMappingObs as $champ) { |
if (!isset($this->mappingObservation[$champ])) { |
$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;'; |
} |
} |
} |
} |
|
|
if (empty($this->mappingCommentaire)) { |
$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_commentaire] ou celui-ci est vide ;'; |
} else { |
$champsMappingCom = array('id_commentaire', 'texte', 'ce_utilisateur', 'utilisateur_nom', 'utilisateur_prenom', 'utilisateur_courriel', 'date'); |
$champsMappingCom = array('id_commentaire', 'texte', 'ce_utilisateur', 'utilisateur_nom', |
'utilisateur_prenom', 'utilisateur_courriel', 'date'); |
foreach ($champsMappingCom as $champ) { |
if (!isset($this->mappingCommentaire[$champ])) { |
$erreurs[] = '- le mapping du champ "'.$champ.'" pour le commentaire est manquant ;'; |
215,7 → 205,7 |
} |
} |
} |
|
|
if (empty($this->mappingFiltre)) { |
$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_masque] ou celui-ci est vide ;'; |
} else { |
223,10 → 213,10 |
foreach ($champsMappingFiltre as $champ) { |
if (!isset($this->mappingFiltre[$champ])) { |
$erreurs[] = '- le mapping du champ "'.$champ.'" pour l\'observation est manquant ;'; |
} |
} |
} |
} |
|
|
if (!empty($erreurs)) { |
$e = 'Erreur lors de la configuration : '."\n"; |
$e .= implode("\n", $erreurs); |
233,9 → 223,7 |
throw new Exception($e, RestServeur::HTTP_CODE_ERREUR); |
} |
} |
|
|
|
|
/** |
* Obtenir une chaine de caractère concaténant nom et prénom séparé par une virgule |
* @param String $auteurId l'identifiant de l'auteur |
247,7 → 235,7 |
$chaineNomPrenom = implode(', ', $nomPrenom); |
return $chaineNomPrenom; |
} |
|
|
/** |
* Charger la clause WHERE en fonction des paramètres de masque |
* */ |
255,20 → 243,19 |
$where = array(); |
$tableauMasque = $this->masque->getMasque(); |
if (!empty($tableauMasque)) { |
foreach($tableauMasque as $idMasque => $valeurMasque) { |
|
foreach ($tableauMasque as $idMasque => $valeurMasque) { |
$idMasque = str_replace('masque.', '', $idMasque); |
switch ($idMasque) { |
// nom du masque => nom BDD |
case 'auteur' : |
$whereAuteur = ' '.$this->creerFiltreAuteur($this->masque->getMasque('auteur')); |
if($whereAuteur != '') { |
if ($whereAuteur != '') { |
$where[] = $whereAuteur; |
} |
break; |
case 'date' : |
$whereDate = ' '.$this->creerFiltreDate($valeurMasque); |
if($whereDate != '') { |
if ($whereDate != '') { |
$where[] = $whereDate; |
} |
break; |
283,18 → 270,18 |
break; |
case 'ns' : |
$where[] = ' nom_sel LIKE '.$this->proteger($valeurMasque.'%'); |
break; |
break; |
case 'commune' : |
$where[] = ' '.$this->mappingFiltre[$idMasque].' LIKE '.$this->proteger(str_replace(array('-',' '), '_', $valeurMasque).'%'); |
break; |
break; |
case 'masque' : |
$where[] = ' '.$this->creerFiltreMasqueGeneral($valeurMasque); |
break; |
break; |
case 'type' : |
//TODO : en discussion doit faire ressortir les observations qui ont plusieurs propositions de nom OU celle qui ont plus de N commentaires |
$tableauTypes = explode(';', $valeurMasque); |
$requeteType = array(); |
|
|
if (in_array('adeterminer', $tableauTypes)) { |
//On récupère toutes les observations qui on le tag "aDeterminer" ou qui n'ont pas de nom d'espèce |
$requeteType[] = '(dob.mots_cles_texte = '.$this->proteger($this->conteneur->getParametre('tag_adeterminer')).' OR nom_sel_nn IS NULL) '; |
304,7 → 291,7 |
//On récupère toutes les observations qui ne sont pas "aDeterminer" et qui ont un nom d'espèce |
$requeteType[] = '(nom_sel is not null AND dob.mots_cles_texte NOT LIKE '.$this->proteger($this->conteneur->getParametre('tag_adeterminer')).') '; |
} |
|
|
if (in_array('endiscussion', $tableauTypes)) { |
//Si on veut les observations en discussion, on va récupérer les ids des observations dont le nombre de commentaire est supérieur à N |
$idsObservations = $this->chargerIdsObservationsParNbCommentaires(); |
314,17 → 301,17 |
$requeteType[] = 'dob.id_observation IN (NULL) '; |
} |
} |
if($valeurMasque != '') { |
if ($valeurMasque != '') { |
$where[] = implode(' OR ', $requeteType); |
} |
break; |
break; |
default: |
$where[] = ' '.$this->mappingFiltre[$idMasque].' = '.$this->proteger($valeurMasque); |
break; |
break; |
} |
} |
} |
} |
|
|
if (!empty($where)) { |
return ' WHERE '.implode('AND', $where); |
} else { |
331,40 → 318,43 |
return; |
} |
} |
|
|
public function chargerIdsObservationsParNbCommentaires() { |
$requeteIdsObservations = 'SELECT ce_observation FROM `del_commentaire` GROUP BY ce_observation HAVING count(id_commentaire) > '.$this->conteneur->getParametre('nb_commentaires_discussion'); |
$requeteIdsObservations = 'SELECT ce_observation '. |
'FROM del_commentaire '. |
'GROUP BY ce_observation '. |
'HAVING count(id_commentaire) > '.$this->conteneur->getParametre('nb_commentaires_discussion'); |
$listeIdsObservations = $this->bdd->recupererTous($requeteIdsObservations); |
$idsObservations = ''; |
foreach ($listeIdsObservations as $idObservation) { |
$idsObservations .= $idObservation['ce_observation'].','; |
|
|
} |
$idsObservations = rtrim($idsObservations, ','); |
return $idsObservations; |
} |
|
|
private function creerFiltreMasqueGeneral($valeurMasque) { |
//TODO: affecter d'aborder les variables, puis les tester pour les |
// ajouter à la chaine |
$whereAuteur = $this->creerFiltreAuteur($valeurMasque); |
$whereIdZoneGeo = $this->creerFiltreIdZoneGeo($valeurMasque); |
|
|
$masqueGeneral = '( '. |
(($whereAuteur != '') ? $whereAuteur.' OR ' : '' ). |
(($whereIdZoneGeo != '') ? $whereIdZoneGeo.' OR ' : '' ). |
'zone_geo LIKE '.$this->proteger($this->remplacerParJokerCaractere($valeurMasque).'%').' OR '. |
$this->creerFiltreMotsCles($valeurMasque).' OR '. |
'nom_sel LIKE '.$this->proteger($valeurMasque.'%').' OR '. |
'famille LIKE '.$this->proteger($valeurMasque.'%').' OR '. |
'milieu LIKE '.$this->proteger($valeurMasque).' OR '. |
$this->mappingFiltre['ns'].' LIKE '.$this->proteger('%'.$valeurMasque.'% %').' OR '. |
$this->creerFiltreDate($valeurMasque). |
') '; |
|
(($whereAuteur != '') ? $whereAuteur.' OR ' : '' ). |
(($whereIdZoneGeo != '') ? $whereIdZoneGeo.' OR ' : '' ). |
'zone_geo LIKE '.$this->proteger($this->remplacerParJokerCaractere($valeurMasque).'%').' OR '. |
$this->creerFiltreMotsCles($valeurMasque).' OR '. |
'nom_sel LIKE '.$this->proteger($valeurMasque.'%').' OR '. |
'famille LIKE '.$this->proteger($valeurMasque.'%').' OR '. |
'milieu LIKE '.$this->proteger($valeurMasque).' OR '. |
$this->mappingFiltre['ns'].' LIKE '.$this->proteger('%'.$valeurMasque.'% %').' OR '. |
$this->creerFiltreDate($valeurMasque). |
') '; |
|
return $masqueGeneral; |
} |
|
|
private function creerFiltreAuteur($valeurMasque) { |
$masque = ''; |
$auteurId = $valeurMasque; |
376,59 → 366,58 |
if(count($tableauNomPrenom) == 2) { |
// on teste potentiellement un nom prenom ou bien un prénom nom |
$masque = '('. |
'(nom LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '. |
'prenom LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '. |
'(nom LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '. |
'prenom LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '. |
'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '. |
'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').') '. |
')'; |
'(nom LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '. |
'prenom LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '. |
'(nom LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '. |
'prenom LIKE '.$this->proteger($tableauNomPrenom[0].'%').') OR '. |
'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').' AND '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').') OR '. |
'(dob.nom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[1].'%').' AND '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($tableauNomPrenom[0].'%').') '. |
')'; |
} else { |
$masque = '( |
(nom LIKE '.$this->proteger($auteurId.'%').' OR '. |
'prenom LIKE '.$this->proteger($auteurId.'%').' OR '. |
'dob.nom_utilisateur LIKE '.$this->proteger($auteurId.'%').' OR '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($auteurId.'%').')'. |
')'; |
(nom LIKE '.$this->proteger($auteurId.'%').' OR '. |
'prenom LIKE '.$this->proteger($auteurId.'%').' OR '. |
'dob.nom_utilisateur LIKE '.$this->proteger($auteurId.'%').' OR '. |
'dob.prenom_utilisateur LIKE '.$this->proteger($auteurId.'%').')'. |
')'; |
} |
} else { |
$masque = " courriel LIKE ".$this->proteger($valeurMasque.'%'). |
" OR dob.courriel_utilisateur LIKE ".$this->proteger($valeurMasque.'%')." "; |
$masque = ' courriel LIKE '.$this->proteger($valeurMasque.'%'). |
' OR dob.courriel_utilisateur LIKE '.$this->proteger($valeurMasque.'%').' '; |
} |
} |
return $masque; |
} |
|
|
private function remplacerParJokerCaractere($valeurMasque) { |
return str_replace(array('-',' '), '_', $valeurMasque); |
} |
|
//TODO: déplacer les fonctions ci dessus et dessous dans une classe |
// utilitaire |
function supprimerAccents($str, $charset='utf-8') |
{ |
function supprimerAccents($str, $charset='utf-8') { |
$str = htmlentities($str, ENT_NOQUOTES, $charset); |
|
|
$str = preg_replace('#&([A-za-z])(?:acute|cedil|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str); |
$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. 'œ' |
$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères |
|
|
return $str; |
} |
|
|
private function obtenirIdDepartement($nomDpt) { |
|
$nomDpt = $this->supprimerAccents($nomDpt); |
$nomDpt = strtolower(str_replace(' ','-',$nomDpt)); |
|
|
$idDpt = $this->conteneur->getParametre($nomDpt); |
if($idDpt == null || $idDpt == ' ') { |
if ($idDpt == null || $idDpt == ' ') { |
$idDpt = ' '; |
} |
return $idDpt; |
} |
|
|
private function creerFiltreIdZoneGeo($valeurMasque) { |
$masque = ''; |
$dept = $valeurMasque; |
447,17 → 436,16 |
} |
return $masque; |
} |
|
|
private function creerFiltreDate($valeurMasque) { |
//TODO: définir dans le fichier de config un tableau contenant plusieurs format de date |
// autorisés pour la recherche, qui seraient ajoutés au OR |
$masque = '('; |
$masque .= (is_numeric($valeurMasque)) ? ' YEAR(date_observation) = '.$this->proteger($valeurMasque).' OR ' : ''; |
$masque .= " DATE_FORMAT(date_observation, '%d/%m/%Y') = ".$this->proteger($valeurMasque).' '. |
')'; |
$masque .= " DATE_FORMAT(date_observation, '%d/%m/%Y') = ".$this->proteger($valeurMasque).' )'; |
return $masque; |
} |
|
|
private function creerFiltreMotsCles($valeurMasque) { |
$mots_cles = explode(' ', $valeurMasque); |
$requeteMotsClesImg = ''; |
466,66 → 454,63 |
// comme avec implode (attention au fait que l'on concatène des % au début et à la fin) |
foreach($mots_cles as $mot_cle) { |
$requeteMotsCles = $this->proteger('%'.$mot_cle.'%'); |
$requeteMotsClesImg .= 'di.mots_cles_texte LIKE '.$requeteMotsCles.' AND '; |
$requeteMotsClesObs .= 'dob.mots_cles_texte LIKE '.$requeteMotsCles.' AND '; |
$requeteMotsClesImg .= "di.mots_cles_texte LIKE $requeteMotsCles AND "; |
$requeteMotsClesObs .= "dob.mots_cles_texte LIKE $requeteMotsCles AND "; |
} |
$requeteMotsClesImg = rtrim($requeteMotsClesImg, ' AND '); |
$requeteMotsClesObs = rtrim($requeteMotsClesObs, ' AND '); |
|
$masque = '('. |
'('.$requeteMotsClesImg.') OR '. |
'('.$requeteMotsClesObs.') '. |
') '; |
|
return $masque; |
|
$masque = "( ($requeteMotsClesImg) OR ($requeteMotsClesObs) ) "; |
return $masque; |
} |
|
|
/*------------------------------------------------------------------------------- |
CHARGEMENT DES OBSERVATIONS |
CHARGEMENT DES OBSERVATIONS |
--------------------------------------------------------------------------------*/ |
/** |
* Chargement depuis la bdd de toutes les liaisons entre images et observations |
* */ |
private function chargerLiaisons() { |
|
$requeteLiaisons = 'SELECT SQL_CALC_FOUND_ROWS dob.id_observation, nom_sel, famille, ce_zone_geo, zone_geo, lieudit, '. |
'station, milieu, date_observation, dob.mots_cles_texte, date_transmission, di.id_image, '. |
'dob.ce_utilisateur, prenom, nom, courriel, '. |
'dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, '. |
'nom_original, dob.commentaire as dob_commentaire, '. |
'dob.nt, dob.nom_sel_nn '. |
'FROM '.$this->gestionBdd->formaterTable('del_observation', 'dob'). |
'LEFT JOIN del_utilisateur du '. |
'ON du.id_utilisateur = dob.ce_utilisateur '. |
'LEFT JOIN '.$this->gestionBdd->formaterTable('del_obs_image', 'doi'). |
'ON doi.id_observation = dob.id_observation '. |
'LEFT JOIN del_image di '. |
'ON di.id_image = doi.id_image '; |
$requeteLiaisons .= $this->chargerClauseWhere(); |
$requeteLiaisons .= ' GROUP BY doi.id_observation'; |
$requeteLiaisons .= ' ORDER BY '.$this->tri.' '.$this->directionTri.' '; |
$requeteLiaisons .= $this->gestionBdd->getLimitSql(); |
|
$requeteLiaisons = 'SELECT SQL_CALC_FOUND_ROWS '. |
' dob.id_observation, nom_sel, famille, ce_zone_geo, zone_geo, lieudit, '. |
' station, milieu, date_observation, dob.mots_cles_texte, date_transmission, di.id_image, '. |
' dob.ce_utilisateur, prenom, nom, courriel, '. |
' dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, '. |
' nom_original, dob.commentaire AS dob_commentaire, '. |
' dob.nt, dob.nom_sel_nn '. |
'FROM del_observation AS dob '. |
' LEFT JOIN del_utilisateur AS du '. |
' ON du.id_utilisateur = dob.ce_utilisateur '. |
' LEFT JOIN del_obs_image AS doi '. |
' ON doi.id_observation = dob.id_observation '. |
' LEFT JOIN del_image AS di '. |
' ON di.id_image = doi.id_image '. |
$this->chargerClauseWhere(). |
' GROUP BY doi.id_observation'. |
' ORDER BY '.$this->tri.' '.$this->directionTri.' '. |
$this->gestionBdd->getLimitSql(); |
|
return $this->bdd->recupererTous($requeteLiaisons); |
} |
|
|
|
private function chargerLiaisonsSimple() { |
$requeteObs = 'SELECT SQL_CALC_FOUND_ROWS dob.id_observation, nom_sel, famille, ce_zone_geo, zone_geo, lieudit, '. |
'station, milieu, date_observation, dob.mots_cles_texte, date_transmission, '. |
'dob.ce_utilisateur, prenom, nom, courriel, '. |
'dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, '. |
'dob.commentaire as dob_commentaire, '. |
'dob.nt, dob.nom_sel_nn '. |
'FROM del_observation dob '. |
' LEFT JOIN del_utilisateur du ON dob.ce_utilisateur = du.id_utilisateur '. |
' ORDER BY id_observation DESC '; |
$requeteObs .= $this->gestionBdd->getLimitSql(); |
$requeteObs = 'SELECT SQL_CALC_FOUND_ROWS '. |
' dob.id_observation, nom_sel, famille, ce_zone_geo, zone_geo, lieudit, '. |
' station, milieu, date_observation, dob.mots_cles_texte, date_transmission, '. |
' dob.ce_utilisateur, prenom, nom, courriel, '. |
' dob.prenom_utilisateur, dob.nom_utilisateur, dob.courriel_utilisateur, '. |
' dob.commentaire as dob_commentaire, '. |
' dob.nt, dob.nom_sel_nn '. |
'FROM del_observation AS dob '. |
' LEFT JOIN del_utilisateur AS du |
ON dob.ce_utilisateur = du.id_utilisateur '. |
'ORDER BY id_observation DESC '. |
$this->gestionBdd->getLimitSql(); |
$liaisons = $this->bdd->recupererTous($requeteObs); |
|
return $liaisons; |
} |
|
|
/** |
* Compter le nombre total d'images dans la base pour affichage dans entete. |
* */ |
534,25 → 519,24 |
$resultats = $this->bdd->recuperer($requete); |
return (int) $resultats['nbre']; |
} |
|
|
/** |
* Retourner un tableau d'images formaté en fonction des liaisons trouvées |
* @param $liaisons les liaisons de la table del_obs_images |
* */ |
private function chargerObservations($liaisons) { |
|
$observations = array(); |
foreach ($liaisons as $liaison) { |
$idObs = $liaison[$this->mappingObservation['id_observation']]; |
|
|
if($liaison['ce_utilisateur'] == 0) { |
$liaison['prenom'] = $liaison['prenom_utilisateur']; |
$liaison['nom'] = $liaison['nom_utilisateur']; |
} |
|
|
$observation = $this->formaterObservation($liaison); |
|
// attention, il est important que les index du tableau soient des chaines |
|
// attention, il est important que les index du tableau soient des chaines |
// de caractères pour que l'ordre d'insertion soit respecté lors de la lecture |
// du json par les navigateur (voir bug du moteur javascript v8 #164) |
$observations['"'.$idObs.'"'] = $observation; |
559,28 → 543,28 |
} |
return $observations; |
} |
|
|
/** |
* Sélectionner toutes les images de chaque observation |
* @param array $observations la liste des observations |
* @param array $observations la liste des observations |
* */ |
private function chargerImages($observations) { |
|
$idObs = $observation['id_observation']; |
foreach ($observations as $id => $observation) { |
|
$requeteImages = 'SELECT * FROM '. $this->gestionBdd->formaterTable('del_obs_image', 'doi'). |
'INNER JOIN '.$this->gestionBdd->formaterTable('del_image', 'di'). |
'ON doi.id_image = di.id_image '. |
'WHERE doi.id_observation = '.$observation['id_observation']; |
|
$requeteImages = 'SELECT * '. |
'FROM del_obs_image AS doi '. |
' INNER JOIN del_image AS di '. |
' ON doi.id_image = di.id_image '. |
"WHERE doi.id_observation = $idObs "; |
|
$images = $this->bdd->recupererTous($requeteImages); |
$images = $this->formaterImages($images); |
$observations[$id]['images'] = $images; |
} |
|
|
return $observations; |
} |
|
|
/** |
* Récupérer toutes les déterminations et le nombre de commentaire au total |
* @param array $observations la liste des observations à mettre à jour |
587,23 → 571,27 |
* */ |
private function chargerDeterminations($observations) { |
foreach ($observations as $id => $observation) { |
$requetePropositions = 'SELECT * FROM '.$this->gestionBdd->formaterTable('del_commentaire', 'dc'). |
'WHERE dc.nom_sel IS NOT NULL AND ce_observation = '.$observation['id_observation']; |
$idObs = $observation['id_observation']; |
$requetePropositions = 'SELECT * '. |
'FROM del_commentaire AS dc '. |
'WHERE dc.nom_sel IS NOT NULL '. |
" AND ce_observation = $idObs "; |
$propositions = $this->bdd->recupererTous($requetePropositions); |
$observations[$id]['commentaires'] = $this->formaterDeterminations($propositions); |
} |
return $observations; |
} |
|
|
/** |
* Charger les votes sur les déterminations |
* @param Array $observations le tableau des observations à mettre à jour |
* */ |
private function chargerVotes($ids_proposition, $propositions) { |
$requeteVotes = 'SELECT * FROM '. |
$this->gestionBdd->formaterTable('del_commentaire_vote'). |
'WHERE ce_proposition IN ('.implode(', ', $ids_proposition).')'; |
|
$listePropositions = implode(', ', $ids_proposition); |
$requeteVotes = 'SELECT * '. |
'FROM del_commentaire_vote '. |
"WHERE ce_proposition IN ($listePropositions)"; |
|
$resultatsVotes = $this->bdd->recupererTous($requeteVotes); |
foreach ($resultatsVotes as $vote) { |
$propositions[$vote['ce_proposition']]['votes'][$vote['id_vote']] = $this->formaterVote($vote); |
610,19 → 598,20 |
} |
return $propositions; |
} |
|
|
/** |
* Charger le nombre de commentaires (sans détermination) associé à l'observation |
* @param Array $observations le tableau des observatins à mettre à jour |
* */ |
private function chargerNombreCommentaire($ids_proposition, $propositions) { |
$requeteNbCommentaires = 'SELECT ce_commentaire_parent, ce_proposition, count( id_commentaire ) AS nb '. |
'FROM del_commentaire '. |
'WHERE ce_proposition IN ( '.implode(', ', $ids_proposition).') '. |
'GROUP BY ce_proposition'; |
$listePropositions = implode(', ', $ids_proposition); |
$requeteNbCommentaires = 'SELECT ce_commentaire_parent, ce_proposition, COUNT( id_commentaire ) AS nb '. |
'FROM del_commentaire '. |
"WHERE ce_proposition IN ($listePropositions) ". |
'GROUP BY ce_proposition '; |
|
$listeCommentaires = $this->bdd->recupererTous($requeteNbCommentaires); |
|
|
foreach ($listeCommentaires as $ligneProposition) { |
// ce test sert à exclure les proposition de 1er niveau qui sont elles aussi des commentaires |
if($ligneProposition['ce_commentaire_parent'] != null && $ligneProposition['ce_commentaire_parent'] != 0) { |
631,15 → 620,13 |
$propositions[$ligneProposition['ce_proposition']]['observation']['nb_commentaires'] = $ligneProposition['nb']; |
} |
} |
|
|
return $propositions; |
} |
|
|
/*------------------------------------------------------------------------------- |
FORMATER ET METTRE EN FORME |
--------------------------------------------------------------------------------*/ |
|
|
/** |
* Formater les images d'une observation |
* @param array $images les images de l'observation |
653,13 → 640,12 |
$imageCourante['binaire.href'] = $this->formaterLienImage($image['id_image']); |
$imageCourante['hauteur'] = $image['hauteur']; |
$imageRetour['largeur'] = $image['largeur']; |
|
|
$imagesRetour[] = $imageCourante; |
} |
|
return $imagesRetour; |
} |
|
} |
|
/** |
* Formater une observation depuis une ligne liaison |
* @param $liaison liaison issue de la recherche |
671,10 → 657,9 |
$observation[$nomFinal] = $liaison[$nomOriginal]; |
} |
$observation['images'] = array(); |
|
return $observation; |
} |
|
|
/** |
* Formater le lien de l'image en fonction du fichier de config et de l'identifiant de l'image |
* */ |
684,19 → 669,18 |
$urlImage = str_replace('%s', $idImage, $url); |
return $urlImage; |
} |
|
|
/** |
* |
* |
* Formate une liste de proposition en fonction du fichier de configuration |
*/ |
private function formaterDeterminations($listePropositions) { |
|
$propositions_format = array(); |
if ($listePropositions != array()) { |
foreach ($listePropositions as $id => $proposition) { |
$ids_proposition[] = $proposition['id_commentaire']; |
|
$proposition_formatee = array('nb_commentaires' => "0"); |
|
$proposition_formatee = array('nb_commentaires' => '0'); |
foreach ($this->mappingCommentaire as $nomOriginal => $nomFinal) { |
if (isset($proposition[$nomOriginal])) { |
$proposition_formatee[$nomFinal] = $proposition[$nomOriginal]; |
704,14 → 688,12 |
} |
$propositions_format[$proposition['id_commentaire']] = $proposition_formatee; |
} |
|
$propositions_format = $this->chargerVotes($ids_proposition, $propositions_format); |
$propositions_format = $this->chargerNombreCommentaire($ids_proposition, $propositions_format); |
|
} |
return $propositions_format; |
} |
|
|
/** |
* Formater un vote en fonction du fichier de configuration config_votes.ini |
* @param $votes array() |
723,7 → 705,7 |
} |
return $retour; |
} |
|
|
private function proteger($valeur) { |
if (is_array($valeur)) { |
return $this->bdd->protegerTableau($valeur); |