Rev 696 | Rev 702 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php/*** Service fournissant des statistiques de l'application CEL au format texte (JSON).* Encodage en entrée : utf8* Encodage en sortie : utf8** Cas d'utilisation :* /CelStatistiqueTxt/TypeDeStat : retourne les statistiques demandées* Paramêtres :* utilisateur=courriel : retourne les statistiques d'un utilisateur donné.** @author Jean-Pascal MILCENT <jpm@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 Copyright (c) 2011, Tela Botanica (accueil@tela-botanica.org)*/class CelStatistiqueTxt extends Cel {/*** Méthode appelée avec une requête de type GET.*/public function getElement($ressources) {$graph = null;$serveur = '';if (isset($ressources[0])) {$this->analyserParametresUrl();$stat_demande = array_shift($ressources);$methode = 'get'.$stat_demande;if (method_exists($this, $methode)) {$stats = $this->$methode($ressources);} else {$this->messages[] = "Ce type de statistiques '$stat_demande' n'est pas disponible.";}} else {$this->messages[] = "La ressource du service CEL StatistiqueTxt doit indiquer le type de statistique. Ex. : .../CelStatistiqueTxt/Nombres";}if (!is_null($stats)) {$this->envoyerJson($stats);}}private function analyserParametresUrl() {$this->parametres['utilisateur'] = isset($_GET['utilisateur']) ? $this->bdd->quote($_GET['utilisateur']) : null;$this->parametres['num_taxon'] = isset($_GET['num_taxon']) ? $this->bdd->quote($_GET['num_taxon']) : null;}private function getNombres($param) {$requete = $this->construireRequeteNbreObs();$info['observations'] = (int) $this->executerRequete($requete, 'Column');$requete = $this->construireRequeteNbreObsPubliques();$info['observationsPubliques'] = (int) $this->executerRequete($requete, 'Column');$requete = $this->construireRequeteNbreImg();$info['images'] =(int) $this->executerRequete($requete, 'Column');$requete = $this->construireRequeteNbreImgLiees();$info['imagesLiees'] =(int) $this->executerRequete($requete, 'Column');$requete = $this->construireRequeteNbreObsLiees();$info['observationsLiees'] = (int) $this->executerRequete($requete, 'Column');$info['moyImagesParObs'] = ($info['observationsLiees'] > 0 ? round($info['imagesLiees']/$info['observationsLiees'], 2) : '');$requete = $this->construireRequeteNbreObsParCommune();$info['communes'] = ($resultats = $this->executerRequete($requete)) ? count($resultats) : '' ;$info['observationsParCommunesMin'] = 1000;$info['observationsParCommunesMax'] = 0;$info['observationsParCommunesTotal'] = 0;foreach ($resultats as $resultat) {if ($resultat['nbre'] < $info['observationsParCommunesMin']) {$info['observationsParCommunesMin'] = $resultat['nbre'];}if ($resultat['nbre'] > $info['observationsParCommunesMax']) {$info['observationsParCommunesMax'] = $resultat['nbre'];}$info['observationsParCommunesTotal'] += $resultat['nbre'];}$info['observationsParCommunesMoyenne'] = round($info['observationsParCommunesTotal'] / $info['communes'], 2);return $info;}private function construireRequeteNbreObs() {$requete = 'SELECT COUNT(id) AS nbre '.'FROM cel_inventory ';if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "identifiant = $utilisateur ";}if (isset($num_taxon)) {$filtres[] = "num_taxon = $num_taxon ";}$requete .= ((count($filtres) > 0) ? 'WHERE '.implode(' AND ', $filtres) : '');}return $requete;}private function construireRequeteNbreObsPubliques() {$requete = 'SELECT COUNT(id) AS nbre '.'FROM cel_inventory '."WHERE transmission = 1 ";if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "identifiant = $utilisateur ";}if (isset($num_taxon)) {$filtres[] = "num_taxon = $num_taxon ";}$requete .= ((count($filtres) > 0) ? 'AND '.implode(' AND ', $filtres) : '');}return $requete;}private function construireRequeteNbreObsParCommune() {$requete = 'SELECT COUNT(id) AS nbre '.'FROM cel_inventory '."WHERE location != '000null' "." AND id_location != '000null' ";$groupBy = 'GROUP BY location, id_location';if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "identifiant = $utilisateur ";}if (isset($num_taxon)) {$filtres[] = "num_taxon = $num_taxon ";}$requete .= ((count($filtres) > 0) ? 'AND '.implode(' AND ', $filtres) : '');}$requete .= $groupBy;return $requete;}private function construireRequeteNbreImg() {$select = 'SELECT COUNT(DISTINCT ci_id_image) AS nbre ';$from = 'FROM cel_images ';if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "ci_ce_utilisateur = $utilisateur ";}if (isset($num_taxon)) {$from .= 'LEFT JOIN cel_obs_images ON (coi_ce_image = ci_id_image) '.'LEFT JOIN cel_inventory ON (coi_ce_observation = ordre AND coi_ce_utilisateur = identifiant) ';$filtres[] = "num_taxon = $num_taxon ";}$where = ((count($filtres) > 0) ? 'WHERE '.implode(' AND ', $filtres) : '');}$requete = $select.$from.$where;return $requete;}private function construireRequeteNbreImgLiees() {$select = 'SELECT COUNT(DISTINCT ci_id_image) AS nbre ';$from = 'FROM cel_obs_images '.' LEFT JOIN cel_images ON (coi_ce_image = ci_id_image) ';if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "coi_ce_utilisateur = $utilisateur ";}if (isset($num_taxon)) {$from .= 'LEFT JOIN cel_inventory ON (coi_ce_observation = ordre AND coi_ce_utilisateur = identifiant) ';$filtres[] = "num_taxon = $num_taxon ";}$where = ((count($filtres) > 0) ? 'WHERE '.implode(' AND ', $filtres) : '');}$requete = $select.$from.$where;return $requete;}private function construireRequeteNbreObsLiees() {$select = 'SELECT COUNT(DISTINCT coi_ce_observation) AS nbre ';$from = 'FROM cel_obs_images '.' LEFT JOIN cel_inventory ON (coi_ce_observation = ordre AND coi_ce_utilisateur = identifiant) ';if (count($this->parametres) != 0) {$filtres = array();extract($this->parametres);if (isset($utilisateur)) {$filtres[] = "identifiant = $utilisateur ";}if (isset($num_taxon)) {$filtres[] = "num_taxon = $num_taxon ";}$where = ((count($filtres) > 0) ? 'WHERE '.implode(' AND ', $filtres) : '');}$requete = $select.$from.$where;return $requete;}}?>