Subversion Repositories eFlore/Projets.eflore-projets

Compare Revisions

Ignore whitespace Rev 1110 → Rev 1111

/trunk/services/modules/0.1/commun/Commun.php
22,6 → 22,7
/** Objet Rest Client. */
private $RestClient = null;
 
/** par défaut : configuration du projet, section [NomDuService] */
protected $config;
 
/** Contients les paramètres. Doit remplacer table_param. */
43,13 → 44,16
protected $table_version; //Stocke les noms des tables de toutes les versions du projet disponibles
/** tableau contenant tous les champs d'une table (est rempli par la fonction Commun::recupererNomChamp($table)) */
protected $champs_table = array();
private static $tri_multi_dimension = array();
private static $tri_type = '';
 
public function __construct($config = null) {
public function __construct($bdd = null, $config = null) {
$this->Bdd = is_null($bdd) ? $this->getBdd() : $bdd;
$this->config = is_null($config) ? Config::get($this->serviceNom) : $config;
$this->init();
}
 
// ajustements post-constructeur
protected function init() {}
 
public function consulter($ressources, $parametres) {
$this->ressources = $ressources;
$this->parametres = $parametres;
/trunk/services/modules/0.1/chorodep/Noms.php
3,7 → 3,7
* Retourne la liste des noms répertoriés par le projet chorodep
*
* @package chorodep
* @author Tela Botanica <equipe-dev@tela-botanica.org>
* @author Mathias Chouet <mathias@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 1.0
20,17 → 20,12
protected $tri;
protected $tri_dir;
 
public function __construct($config = null) {
parent::__construct($config);
protected function init() {
$this->masque = array();
$this->depart = 0;
$this->limite = 20;
$this->tri = 'nom_sci';
$this->tri_dir = 'ASC';
$this->init();
}
 
protected function init() {
$this->traiterVersionProjet();
$this->table = $this->table_version[0];
}
/trunk/services/modules/0.1/chorodep/InfosEspece.php
New file
0,0 → 1,178
<?php
/**
* Retourne des infos sur une espèce : noms vernaculaires français, statuts de
* protection, num_nom, num_tax, nom_sci, et nombre de zones dans lesquelles elle
* est présente.
* Interrogeable par nn ou nt
*
* Il faudrait appeler les services correspondants pour obtenir les infos sur les
* noms vernaculaires et les statuts de protection, mais c'est pas performant.
* Néanmoins ce serait une arcitecture plus solide en cas de changement - pas le
* temps d'y réfléchir mieux.
*
* @package chorodep
* @author Mathias Chouet <mathias@tela-botanica.org>
* @author Aurélien Perronnet <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 1.0
* @copyright 1999-2014 Tela Botanica (accueil@tela-botanica.org)
*/
 
class InfosEspece extends Commun {
 
protected $serviceNom = 'InfosEspece';
protected $masque;
protected $navigation;
protected $table;
protected $tableNomsVernaculaires;
protected $urlStatutsProtection;
 
public function init() {
$this->masque = array();
$this->traiterVersionProjet();
$this->table = $this->table_version[0];
$this->tableNomsVernaculaires = $this->config['table_nv'];
$this->urlStatutsProtection = $this->config['url_service_sptb'];
}
public function consulter($ressources, $parametres) {
 
$retour = null;
if(preg_match("/^(nt|nn):([0-9]+)$/", $ressources[0], $matches)) {
$champ_nt_ou_nn = ($matches[1] == "nn") ? "num_nom" : "num_tax";
 
if(count($ressources) == 1) {
// toutes les infos
$infos_espece = $this->getInfosEspece($champ_nt_ou_nn, $matches[2]);
$retour = array_merge($infos_espece, $this->getInfosPresence($champ_nt_ou_nn, $matches[2]));
$statuts_protection = array(
'statuts_protection' => $this->getStatutsProtection($champ_nt_ou_nn, $matches[2])
);
$retour = array_merge($retour, $statuts_protection);
$noms_vernaculaires = array(
'noms_vernaculaires_fr' => $this->getNomsVernaculaires($champ_nt_ou_nn, $matches[2])
);
$retour = array_merge($retour, $noms_vernaculaires);
} else {
// sous action du service
$retour = array();
switch($ressources[1]) {
case "noms-vernaculaires":
$retour = array('noms_vernaculaires_fr' => $this->getNomsVernaculaires($champ_nt_ou_nn, $matches[2]));
break;
case "statuts-protection":
$retour = array('statuts_protection' => $this->getStatutsProtection($champ_nt_ou_nn, $matches[2]));
break;
case "presence":
$retour = $this->getInfosPresence($champ_nt_ou_nn, $matches[2]);
break;
default:
$retour = "Actions possibles: noms-vernaculaires, statuts-protection, presence";
}
}
} else {
// TODO : envoyer message erreur;
}
return $retour;
}
 
/**
* Toutes les infos sauf noms vernaculaires et statuts de protection
*/
protected function getInfosEspece($champ_nt_ou_nn, $nt_ou_nn) {
$req = "SELECT DISTINCT num_nom, num_tax, nom_sci"
. " FROM " . $this->table
. " WHERE $champ_nt_ou_nn = " . $this->getBdd()->proteger($nt_ou_nn);
 
$resultat = $this->getBdd()->recuperer($req);
 
return $resultat;
}
 
/**
* Construit une opération d'addition entre toutes les colonnes de la table
* chorodep représentant un département
*/
protected function construireSommeColonnes() {
$colonnes = array();
for ($i=1; $i <= 95; $i++) {
$colonnes[] = '`' . ($i > 9 ? $i : "0$i") . '`';
}
$somme = implode('+', $colonnes);
return $somme;
}
 
protected function getInfosPresence($champ_nt_ou_nn, $nt_ou_nn) {
$req = "SELECT " . $this->construireSommeColonnes() . " as nb_presence_zones".
" FROM ".$this->table.
" WHERE ".$champ_nt_ou_nn." = ".$this->getBdd()->proteger($nt_ou_nn);
 
$resultat = $this->getBdd()->recuperer($req);
return $resultat;
}
 
/**
* Appelle le WS sptb car la table ne contient pas toutes les infos (il faut
* agréger les taxons supérieurs)
*/
protected function getStatutsProtection($champ_nt_ou_nn, $nt_ou_nn) {
$num_noms = array();
if ($champ_nt_ou_nn == "num_tax") {
// le service sptb n'accepte pas les nt (on croit que si mais en fait
// non) alors on chope les nn associés à ce nt dans chorodep - c'est
// moisi mais c'est toujours mieux que si c'était pire
$numTaxP = $this->getBdd()->proteger($nt_ou_nn);
$req = "SELECT DISTINCT num_nom"
. " FROM " . $this->table
. " WHERE num_tax = $numTaxP";
 
$resultat = $this->getBdd()->recupererTous($req);
foreach($resultat as $res) {
$num_noms[] = $res['num_nom'];
}
} else {
$num_noms[] = $nt_ou_nn;
}
 
$statuts = array();
// récupération des statuts pour chaque num_nom
foreach ($num_noms as $nn) {
$url = sprintf($this->urlStatutsProtection, $nn);
$donnees = $this->getRestClient()->consulter($url);
$donnees = json_decode($donnees, true);
foreach ($donnees as $d) {
$statuts[] = array(
'zone' => $d['code_zone_application'],
'lien' => $d['hyperlien_legifrance']
);
}
}
 
return $statuts;
}
 
// @TODO faire un appel au WS nvjfl "for the sake of non-nodebagging" ?
protected function getNomsVernaculaires($champ_nt_ou_nn, $nt_ou_nn) {
$numP = $this->getBdd()->proteger($nt_ou_nn);
$req = "SELECT DISTINCT nv.nom_vernaculaire"
. " FROM " . $this->tableNomsVernaculaires . " nv";
if ($champ_nt_ou_nn == "num_nom") {
$req .= " LEFT JOIN " . $this->table . " c ON nv.num_taxon = c.num_tax"
. " WHERE c.num_nom = $numP";
} else {
$req .= " WHERE nv.num_taxon = $numP";
}
$req .= " AND nv.code_langue = 'fra'";
 
$resultat = $this->getBdd()->recupererTous($req);
 
$resultat_fmt = array();
foreach($resultat as $nv) {
$resultat_fmt[] = $nv['nom_vernaculaire'];
}
 
return $resultat_fmt;
}
}
?>
/trunk/services/modules/0.1/sptb/Statuts.php
1,5 → 1,7
<?php
// declare(encoding='UTF-8');
// declare(tension='220v');
// declare(couleur_du_ciel='bleu');
/**
* Classe implémentant l'API d'eFlore concernant les statuts de protection
*
7,10 → 9,11
*
* @package eFlore/services
* @author Aurélien PERONNET <aurelien@tela-botanica.org>
* * @author Mathias CHOUET <mathias@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 1.0
* @copyright 1999-2011 Tela Botanica (accueil@tela-botanica.org)
* @copyright 1999-2014 Tela Botanica (accueil@tela-botanica.org)
*/
// TODO : Config et Outils sont des classes statiques qui doivent poser des pb pour les tests...
class Statuts extends Commun {
17,24 → 20,25
 
protected $parametres = array();
protected $ressources = array();
 
private $bdd;
private $retour_format = 'complet';
private $retours_formats_autorises = array('complet','zone_geo');
protected $nn_demande;
protected $navigation_depart;
protected $navigation_limite;
 
public function __construct($config = null) {
$this->config = $config;
$this->bdd = $this->getBdd();
}
 
public function consulter($ressources, $parametres) {
 
$this->parametres = $parametres;
$this->ressources = $ressources;
 
$this->affecterParametresParDefaut();
$this->verifierParametres();
$this->affecterParametres();
 
$resultat = new ResultatService();
$resultat->corps = $this->obtenirStatuts();
41,27 → 45,49
 
return $resultat;
}
//+---------------------------FONCTION D'ANALYSE DES PARAMETRES---------------------------------------------------------+
 
private function affecterParametresParDefaut() {
$this->retour_format = isset($this->parametres['retour.format']) ? $this->parametres['retour.format'] : $this->retour_format;
}
private function verifierParametres() {
/**
* Affecte et vérifie les paramètres
* @throws Exception
*/
private function affecterParametres() {
$erreurs = array();
if (empty($this->parametres['masque.nn'])) {
$erreurs[] = 'renseignez une valeur pour masque.nn';
 
if (isset($this->parametres['retour.format'])) {
if(!in_array($this->retour_format, $this->retours_formats_autorises)) {
$erreurs[] = 'la valeur '.$this->retour_format.' est inconnue';
}
$this->retour_format = $this->parametres['retour.format'];
}
if(!is_numeric($this->parametres['masque.nn'])) {
$erreurs[] = 'la valeur pour masque.nn doit être un entier';
if (isset($this->parametres['masque.nn']) && ($this->parametres['masque.nn'] != '')) {
if(!is_numeric($this->parametres['masque.nn'])) {
$erreurs[] = 'la valeur pour masque.nn doit être un entier';
}
$this->nn_demande = $this->parametres['masque.nn'];
}
if(!in_array($this->retour_format, $this->retours_formats_autorises)) {
$erreurs[] = 'la valeur '.$this->retour_format.' est inconnue';
if (isset($this->parametres['masque.zone']) && ($this->parametres['masque.zone'] != '')) {
if(!is_numeric($this->parametres['masque.zone']) || !($this->parametres['masque.zone'] > 0 && $this->parametres['masque.zone'] <= 64)) {
$erreurs[] = 'la valeur pour masque.zone doit être un entier compris entre 1 et 64';
}
$this->zone = $this->parametres['masque.zone'];
}
if (isset($this->parametres['navigation.depart']) && ($this->parametres['navigation.depart'] != '')) {
if (!is_numeric($this->parametres['navigation.depart'])) {
$erreurs[] = 'la valeur pour navigation.depart doit être un entier';
}
$this->navigation_depart = max(0, intval($this->parametres['navigation.depart']));
} else {
$this->navigation_depart = 0;
}
if (isset($this->parametres['navigation.limite']) && ($this->parametres['navigation.limite'] != '')) {
if (!is_numeric($this->parametres['navigation.limite'])) {
$erreurs[] = 'la valeur pour navigation.limite doit être un entier';
}
$this->navigation_limite = intval($this->parametres['navigation.limite']);
} else {
$this->navigation_limite = 100;
}
 
if (count($erreurs) > 0) {
$message = implode('<br />', $erreurs);
$code = RestServeur::HTTP_CODE_MAUVAISE_REQUETE;
68,8 → 94,6
throw new Exception($message, $code);
}
}
//+---------------------------FONCTIONS DE REQUETE---------------------------------------------------------+
 
private function obtenirLois(Array $id_lois) {
$id_lois = array_map(array($this->bdd, 'proteger'), $id_lois);
85,18 → 109,26
return $this->bdd->recupererTous($requete);
}
private function obtenirStatuts() {
$nn_demande = $this->parametres['masque.nn'];
private function obtenirStatuts() {
if ($this->nn_demande != null) {
$conditions_taxons = array();
$conditions_taxons = $this->obtenirNumNomTaxonsSuperieurs(Config::get('referentiel'), $this->nn_demande);
$conditions_taxons[] = $this->bdd->proteger($this->nn_demande);
}
$conditions_taxons = array();
$conditions_taxons = $this->obtenirNumNomTaxonsSuperieurs(Config::get('referentiel'), $nn_demande);
$conditions_taxons[] = $this->bdd->proteger($nn_demande);
$requete = "SELECT * FROM ".Config::get('bdd_table_especes').' '.
"WHERE num_nom_retenu IN (".implode(', ', $conditions_taxons).") OR ".
"num_nom IN (".implode(', ', $conditions_taxons).") " . ' -- ' . __FILE__ . ':' . __LINE__;
$requete = "SELECT * FROM ".Config::get('bdd_table_especes');
if ($this->nn_demande != null) {
$requete .= " WHERE num_nom_retenu IN (".implode(', ', $conditions_taxons).") OR "
. "num_nom IN (".implode(', ', $conditions_taxons).") ";
}
// pagination
$requete .= " LIMIT " . $this->navigation_depart . ", " . $this->navigation_limite;
$requete .= ' -- ' . __FILE__ . ':' . __LINE__;
//echo "REQ: $requete\n";
$statuts = $this->bdd->recuperer($requete);
//echo "STATUTS: " . print_r($statuts, true) . "\n";
//echo "CPT: " . count($statuts) . "\n";
$statuts = $this->formaterRetour($statuts);
return $statuts;
}
/trunk/services/configurations/config_chorodep.ini
30,7 → 30,7
; +------------------------------------------------------------------------------------------------------+
; Config spécifique au projet
; Noms des services disponibles pour ce projet
servicesDispo = "meta-donnees,aide,ontologies,observations,cartes,noms"
servicesDispo = "meta-donnees,aide,ontologies,observations,cartes,noms,infos-espece"
 
[Cartes]
; Chemin de base des cartes
41,3 → 41,9
cache_miseEnCache = true
cache_stockageChemin = "{ref:chemin_cache}chorodep/"
cache_dureeDeVie = "php:3600*24"
 
[InfosEspece]
; table des noms vernaculaires
table_nv = "nvjfl_v2007"
; URL des status de protection
url_service_sptb = "http://localhost/service:eflore:0.1/sptb/statuts?masque.nn=%s"