/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/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/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/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 { |
21,8 → 24,10 |
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(); |
33,8 → 38,7 |
$this->parametres = $parametres; |
$this->ressources = $ressources; |
$this->affecterParametresParDefaut(); |
$this->verifierParametres(); |
$this->affecterParametres(); |
$resultat = new ResultatService(); |
$resultat->corps = $this->obtenirStatuts(); |
41,26 → 45,48 |
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 (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'; |
} |
if(!in_array($this->retour_format, $this->retours_formats_autorises)) { |
$erreurs[] = 'la valeur '.$this->retour_format.' est inconnue'; |
$this->nn_demande = $this->parametres['masque.nn']; |
} |
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); |
69,8 → 95,6 |
} |
} |
//+---------------------------FONCTIONS DE REQUETE---------------------------------------------------------+ |
private function obtenirLois(Array $id_lois) { |
$id_lois = array_map(array($this->bdd, 'proteger'), $id_lois); |
$requete = "SELECT * FROM ".Config::get('bdd_table_lois').' '. |
86,17 → 110,25 |
} |
private function obtenirStatuts() { |
$nn_demande = $this->parametres['masque.nn']; |
if ($this->nn_demande != null) { |
$conditions_taxons = array(); |
$conditions_taxons = $this->obtenirNumNomTaxonsSuperieurs(Config::get('referentiel'), $nn_demande); |
$conditions_taxons[] = $this->bdd->proteger($nn_demande); |
$conditions_taxons = $this->obtenirNumNomTaxonsSuperieurs(Config::get('referentiel'), $this->nn_demande); |
$conditions_taxons[] = $this->bdd->proteger($this->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; |
} |