| 1229 | delphine | 1 | <?php
 | 
        
           |  |  | 2 | // declare(encoding='UTF-8');
 | 
        
           |  |  | 3 | /**
 | 
        
           |  |  | 4 | * Classe permettant de fournir des informations sur les noms scientifiques.
 | 
        
           |  |  | 5 | * Si l'url finit par /noms on retourne une liste de noms latin et leurs identifiants (seulement les 100 premeiers noms par défaut).
 | 
        
           |  |  | 6 | * L'url peut contenir des paramètres optionnels passés après le ? : /noms?param1=val1¶m2=val2&...
 | 
        
           |  |  | 7 | *
 | 
        
           |  |  | 8 | * Les paramètres de requête disponibles sont : masque, masque.gen (nom de genre), masque.sp (épithète d'espèce), masque.ssp (épithète infra-spécifique),
 | 
        
           |  |  | 9 | * masque.au (auteur du nom), masque.an (année de publication du nom), masque.bib (réf biblio de la publi d'origine du nom), masque.ad (nomen addendum),
 | 
        
           |  |  | 10 | * masque.nn (identifiant du nom), recherche, rang, distinct, retour.format, nl.format, nl.structure, navigation.depart et navigation.limite.
 | 
        
           |  |  | 11 | * Les différentes requetes :
 | 
        
           |  |  | 12 | *   - noms | noms/relations/#projet/#id_projet | noms/#id | noms/#id/#champ+#champ
 | 
        
           |  |  | 13 | *   - noms/#id/relations | noms/#id/relations/synonymie | noms/#id/relations/homonymie | noms/#id/relations/flores
 | 
        
           |  |  | 14 | *   - noms/stats/rangs | noms/stats/annees | noms/stats/initiales
 | 
        
           |  |  | 15 | *
 | 
        
           |  |  | 16 | * @package bdtfx
 | 
        
           |  |  | 17 | * @author Jennifer Dhé <jennifer.dhe@tela-botanica.org>
 | 
        
           |  |  | 18 | * @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
 | 
        
           |  |  | 19 | * @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
 | 
        
           |  |  | 20 | * @version $Id$
 | 
        
           |  |  | 21 | * @copyright 1999-2011 Tela Botanica (accueil@tela-botanica.org)
 | 
        
           |  |  | 22 | * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=EfloreApi01Noms
 | 
        
           |  |  | 23 | */
 | 
        
           |  |  | 24 |   | 
        
           |  |  | 25 | class Noms extends CommunNomsTaxons {
 | 
        
           |  |  | 26 |   | 
        
           |  |  | 27 | 	protected $format_reponse	 = 'noms'; // Permet de stocker la requete formulée
 | 
        
           |  |  | 28 | 	protected $service 			 = 'noms';
 | 
        
           |  |  | 29 | 	protected $serviceNom		 = 'noms';
 | 
        
           |  |  | 30 | 	protected $requete_champ 	 = 'num_nom, nom_sci, num_nom_retenu';
 | 
        
           |  |  | 31 | 	protected $requete_condition = null;
 | 
        
           |  |  | 32 | 	protected $requete_group_by  = '';
 | 
        
           |  |  | 33 | 	/** Permet de stocker les limite de la requete SQL (par défaut seul les 100 premiers résultats seront retournés).*/
 | 
        
           |  |  | 34 | 	protected $limite_requete 	 = array('depart' => 0, 'limite' => 100);
 | 
        
           |  |  | 35 | 	protected $distinct		 	 = null; // Valeur du paramètre de requete distinct (=0|1)
 | 
        
           |  |  | 36 |   | 
        
           |  |  | 37 | 	public function consulter($ressources, $parametres) {
 | 
        
           |  |  | 38 | 		return parent::consulter($ressources, $parametres);
 | 
        
           |  |  | 39 | 	}
 | 
        
           |  |  | 40 |   | 
        
           |  |  | 41 | //+----------------FONCTION D'ANALYSE DES PARAMETRES---------------------------------------------------------+
 | 
        
           |  |  | 42 |   | 
        
           |  |  | 43 | 	public function traiterParametresSpecifiques() {
 | 
        
           |  |  | 44 | 		foreach ($this->parametres as $param => $val) {
 | 
        
           |  |  | 45 | 			switch ($param) {
 | 
        
           |  |  | 46 | 				case 'masque' :
 | 
        
           |  |  | 47 | 					$champ = isset($this->parametres['recherche']) && ($this->parametres['recherche'] == 'etendue') ?
 | 
        
           |  |  | 48 | 							'CONCAT(nom_sci," ",auteur)' : 'nom_sci';
 | 
        
           |  |  | 49 | 					$this->ajouterFiltreMasque($champ, $val);
 | 
        
           |  |  | 50 | 					break;
 | 
        
           |  |  | 51 | 				case 'masque.sg' :
 | 
        
           |  |  | 52 | 					$this->ajouterFiltreMasque('nom_supra_generique', $val);
 | 
        
           |  |  | 53 | 					break;
 | 
        
           |  |  | 54 | 				case 'masque.gen' :
 | 
        
           |  |  | 55 | 					$this->ajouterFiltreMasque('genre', $val);
 | 
        
           |  |  | 56 | 					break;
 | 
        
           |  |  | 57 | 				case 'masque.sp' :
 | 
        
           |  |  | 58 | 					$this->ajouterFiltreMasque('epithete_sp', $val);
 | 
        
           |  |  | 59 | 					break;
 | 
        
           |  |  | 60 | 				case 'masque.ssp' :
 | 
        
           |  |  | 61 | 					$this->ajouterFiltreMasque('epithete_infra_sp',$val);
 | 
        
           |  |  | 62 | 					break;
 | 
        
           |  |  | 63 | 				case 'masque.au' :
 | 
        
           |  |  | 64 | 					$this->ajouterFiltreMasque('auteur', $val);
 | 
        
           |  |  | 65 | 					break;
 | 
        
           |  |  | 66 | 				case 'masque.an' :
 | 
        
           |  |  | 67 | 					$this->ajouterFiltreMasque('annee', $val);
 | 
        
           |  |  | 68 | 					break;
 | 
        
           |  |  | 69 | 				case 'masque.bib' :
 | 
        
           |  |  | 70 | 					$this->ajouterFiltreMasque('biblio_origine',$val);
 | 
        
           |  |  | 71 | 					break;
 | 
        
           |  |  | 72 | 				case 'masque.ad' :
 | 
        
           |  |  | 73 | 					$this->ajouterFiltreMasque('nom_addendum', $val);
 | 
        
           |  |  | 74 | 					break;
 | 
        
           |  |  | 75 | 				case 'masque.nn' :
 | 
        
           |  |  | 76 | 					$this->requete_condition []= 'num_nom IN ('.$val.')';
 | 
        
           |  |  | 77 | 					$this->masque['num_nom'] = "num_nom=$val";
 | 
        
           |  |  | 78 | 					break;
 | 
        
           |  |  | 79 | 				case 'masque.nt' :
 | 
        
           |  |  | 80 | 					$this->requete_condition []= 'num_taxonomique IN ('.$val.')';
 | 
        
           |  |  | 81 | 					$this->masque['num_tax'] = "num_taxonomique=$val";
 | 
        
           |  |  | 82 | 					break;
 | 
        
           |  |  | 83 | 				case 'masque.rg' :
 | 
        
           |  |  | 84 | 					$this->ajouterFiltreMasque('rang', $val);
 | 
        
           |  |  | 85 | 					break;
 | 
        
           |  |  | 86 | 				case 'retour.champs' :
 | 
        
           |  |  | 87 | 					$this->verifierParamChamps($param, $val);
 | 
        
           |  |  | 88 | 					break;
 | 
        
           |  |  | 89 | 				case 'distinct' :
 | 
        
           |  |  | 90 | 					$this->ajouterNomDistinct($val);
 | 
        
           |  |  | 91 | 					break;
 | 
        
           |  |  | 92 | 				case 'masque.fam' :
 | 
        
           |  |  | 93 | 					$this->ajouterFiltreMasque('famille', $val);
 | 
        
           |  |  | 94 | 					break;
 | 
        
           |  |  | 95 | 				case 'masque.prga' :
 | 
        
           |  |  | 96 | 					$this->ajouterFiltreMasque('presence_ga', $val);
 | 
        
           |  |  | 97 | 					break;
 | 
        
           |  |  | 98 | 				case 'masque.prco' :
 | 
        
           |  |  | 99 | 					$this->ajouterFiltreMasque('presence_co', $val);
 | 
        
           |  |  | 100 | 					break;
 | 
        
           |  |  | 101 | 				case 'masque.sto' :
 | 
        
           |  |  | 102 | 					$this->ajouterFiltreMasque('statut_origine', $val);
 | 
        
           |  |  | 103 | 					break;
 | 
        
           |  |  | 104 | 				case 'masque.sti' :
 | 
        
           |  |  | 105 | 					$this->ajouterFiltreMasque('statut_introduction', $val);
 | 
        
           |  |  | 106 | 					break;
 | 
        
           |  |  | 107 | 				case 'masque.stc' :
 | 
        
           |  |  | 108 | 					$this->ajouterFiltreMasque('statut_culture', $val);
 | 
        
           |  |  | 109 | 					break;
 | 
        
           |  |  | 110 | 				case 'masque.and' :
 | 
        
           |  |  | 111 | 					$this->requete_condition []= " annee >= ".$this->getBdd()->proteger($val);
 | 
        
           |  |  | 112 | 					break;
 | 
        
           |  |  | 113 | 				case 'masque.anf' :
 | 
        
           |  |  | 114 | 					$this->requete_condition []= " annee <= ".$this->getBdd()->proteger($val);
 | 
        
           |  |  | 115 | 					break;
 | 
        
           |  |  | 116 | 			}
 | 
        
           |  |  | 117 |   | 
        
           |  |  | 118 | 		}
 | 
        
           |  |  | 119 | 	}
 | 
        
           |  |  | 120 |   | 
        
           |  |  | 121 | 	public function verifierParamChamps($param, $val) {
 | 
        
           |  |  | 122 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp');
 | 
        
           |  |  | 123 | 		$champs_demandes = explode(',', $val);
 | 
        
           |  |  | 124 | 		$champs_verifies = array();
 | 
        
           |  |  | 125 | 		$champs_api = array_flip($this->champs_api);
 | 
        
           |  |  | 126 | 		$champs_supp = array('nom_retenu_complet'=>'num_nom_retenu', 'num_basionyme_complet'=>'num_basionyme');
 | 
        
           |  |  | 127 | 		$champs_api = array_merge($champs_api, $champs_supp);
 | 
        
           |  |  | 128 | 		foreach ($champs_demandes as $champ) {
 | 
        
           |  |  | 129 | 			if (array_key_exists($champ, $champs_api)) {
 | 
        
           |  |  | 130 | 				$champs_verifies[] = $champs_api[$champ];
 | 
        
           |  |  | 131 | 			}
 | 
        
           |  |  | 132 | 		}
 | 
        
           |  |  | 133 | 		if (count($champs_verifies) > 0) {
 | 
        
           |  |  | 134 | 			$this->requete_champ .= ', '.implode(',', $champs_verifies);
 | 
        
           |  |  | 135 | 		}
 | 
        
           |  |  | 136 | 	}
 | 
        
           |  |  | 137 |   | 
        
           |  |  | 138 | 	/** Permet de rajouter à la requete sql le parametre distinct. N'est utilisé qu'avec le format oss */
 | 
        
           |  |  | 139 | 	public function ajouterNomDistinct($distinct) {
 | 
        
           |  |  | 140 | 		if (isset($distinct)) {
 | 
        
           |  |  | 141 | 			if ($distinct == 1 && $this->parametres['retour.format'] == 'oss') {
 | 
        
           |  |  | 142 | 				$this->distinct = ' distinct ';
 | 
        
           |  |  | 143 | 			} elseif ($distinct == 1 && $this->parametres['retour.format'] != 'oss') {
 | 
        
           |  |  | 144 | 				$e = 'Erreur dans votre requête </br> L\'utilisation du paramètre distinct ne se fait que sous
 | 
        
           |  |  | 145 | 					le format oss';
 | 
        
           |  |  | 146 | 				$this->renvoyerErreur(RestServeur::HTTP_CODE_MAUVAISE_REQUETE, $e);
 | 
        
           |  |  | 147 | 			}
 | 
        
           |  |  | 148 | 		}
 | 
        
           |  |  | 149 | 	}
 | 
        
           |  |  | 150 |   | 
        
           |  |  | 151 | //-----------------FONCTION D'ANALYSE DES RESSOURCES--------------------------------------------------------------------
 | 
        
           |  |  | 152 |   | 
        
           |  |  | 153 | 	public function traiterRessourcesIdentifiant() {
 | 
        
           |  |  | 154 | 		//on initialise la condition de la requete sql et le format de réponse
 | 
        
           |  |  | 155 | 		$this->requete_condition = array(); //on vide la table dans le cas de plusieurs version
 | 
        
           |  |  | 156 | 		$this->requete_condition[] = 'num_nom = '.$this->getBdd()->proteger($this->ressources[0]);
 | 
        
           |  |  | 157 | 		$this->format_reponse = $this->service.'/id';
 | 
        
           |  |  | 158 | 		if (isset($this->ressources[1]) && !empty($this->ressources[1])) {
 | 
        
           |  |  | 159 | 			if ($this->ressources[1] == 'relations') {
 | 
        
           |  |  | 160 | 				$this->traiterRessourceIdRelations();
 | 
        
           |  |  | 161 | 			} else {
 | 
        
           |  |  | 162 | 				$e = 'Erreur dans votre requête </br> Ressources disponibles : <br/>
 | 
        
           |  |  | 163 | 					 <li> noms/#id/relations </li> <li> noms/#id/#champ+#champ </li>
 | 
        
           |  |  | 164 | 					 <li> noms/#id/relations/synonymie </li> <li> noms/#id/relations/flores </li>
 | 
        
           |  |  | 165 | 					 <li> noms/#id/relations/homonymie </li>';
 | 
        
           |  |  | 166 | 				$this->renvoyerErreur(RestServeur::HTTP_CODE_MAUVAISE_REQUETE, $e);
 | 
        
           |  |  | 167 | 			}
 | 
        
           |  |  | 168 | 		} else { // requete de type noms/#id : rajout du nom_sci pour récupérer le format html par la fct mettreAuFormat()
 | 
        
           |  |  | 169 | 			$this->requete_champ = ' *, nom_sci ';
 | 
        
           |  |  | 170 | 		}
 | 
        
           |  |  | 171 | 	}
 | 
        
           |  |  | 172 |   | 
        
           |  |  | 173 | 	public function traiterRessourceRelations() {
 | 
        
           |  |  | 174 | 		$this->format_reponse .= '/relations';
 | 
        
           |  |  | 175 | 		$projet = $this->ressources[1];
 | 
        
           |  |  | 176 | 		$num_nom = $this->ressources[2];
 | 
        
           |  |  | 177 | 		if (strrpos($num_nom, 'nn.coste') !== false) {
 | 
        
           |  |  | 178 | 			list($p, $nn) = explode('=', $num_nom);
 | 
        
           |  |  | 179 | 			$num_nom = $nn;
 | 
        
           |  |  | 180 | 		}
 | 
        
           |  |  | 181 | 		$champ = "flore_$projet"."_num";
 | 
        
           |  |  | 182 | 		if (isset($this->ressources[3])) {
 | 
        
           |  |  | 183 | 			$type = $this->ressources[3];
 | 
        
           |  |  | 184 | 			if (!in_array($type, array('homonymie', 'synonymie', 'flores'))) {
 | 
        
           |  |  | 185 | 				$e = "Les types disponibles pour les noms sont homonymie, synonymie et flores";
 | 
        
           |  |  | 186 | 				$this->renvoyerErreur(RestServeur::HTTP_CODE_MAUVAISE_REQUETE, $e);
 | 
        
           |  |  | 187 | 			}
 | 
        
           |  |  | 188 | 		}
 | 
        
           |  |  | 189 | 		$this->requete_champ = ' num_nom ';
 | 
        
           |  |  | 190 | 		$this->requete_condition = array();
 | 
        
           |  |  | 191 | 		$this->requete_condition[] = "$champ = ".$this->getBdd()->proteger($num_nom);
 | 
        
           |  |  | 192 | 	}
 | 
        
           |  |  | 193 |   | 
        
           |  |  | 194 | 	public function traiterRessourceIdRelations() {
 | 
        
           |  |  | 195 | 		$this->format_reponse .= '/relations';
 | 
        
           |  |  | 196 | 		if (isset($this->ressources[2]) && !empty($this->ressources[2])) {
 | 
        
           |  |  | 197 | 			// requete de type noms/#id/relations/#relation
 | 
        
           |  |  | 198 | 			switch ($this->ressources[2]) {
 | 
        
           |  |  | 199 | 				case 'synonymie' :
 | 
        
           |  |  | 200 | 					$this->traiterRessourceIdSynonymie();
 | 
        
           |  |  | 201 | 					break;
 | 
        
           |  |  | 202 | 				case 'flores' :
 | 
        
           |  |  | 203 | 					$this->traiterRessourceIdFlores();
 | 
        
           |  |  | 204 | 					break;
 | 
        
           |  |  | 205 | 				case 'homonymie' :
 | 
        
           |  |  | 206 | 					$this->traiterRessourceIdHomonymie();
 | 
        
           |  |  | 207 | 					break;
 | 
        
           |  |  | 208 | 				default :
 | 
        
           |  |  | 209 | 					$e = 'Erreur dans votre requête </br> Ressources disponibles : <br/>
 | 
        
           |  |  | 210 | 					 <li> noms/#id/relations </li>  <li> noms/#id/relations/synonymie </li>
 | 
        
           |  |  | 211 | 					 <li> noms/#id/relations/flores </li> <li> noms/#id/relations/homonymie </li>';
 | 
        
           |  |  | 212 | 					$this->renvoyerErreur(RestServeur::HTTP_CODE_MAUVAISE_REQUETE, $e);
 | 
        
           |  |  | 213 | 					break;
 | 
        
           |  |  | 214 | 			}
 | 
        
           |  |  | 215 | 		}
 | 
        
           |  |  | 216 | 	}
 | 
        
           |  |  | 217 |   | 
        
           |  |  | 218 | 	public function traiterRessourceIdSynonymie() {
 | 
        
           |  |  | 219 | 		// SELECT num_nom, nom_sci, num_nom_retenu, num_basionyme FROM bdtfx_v2_00 WHERE num_nom = X LIMIT 0,100;
 | 
        
           |  |  | 220 | 		$this->format_reponse .= '/synonymie';
 | 
        
           |  |  | 221 | 		if (strrpos($this->requete_champ, ', num_basionyme') === false) {
 | 
        
           |  |  | 222 | 			$this->requete_champ .= ', num_basionyme ';
 | 
        
           |  |  | 223 | 		}
 | 
        
           |  |  | 224 | 		if (strrpos($this->requete_champ, ', num_type') === false) {
 | 
        
           |  |  | 225 | 			$this->requete_champ .= ', num_type ';
 | 
        
           |  |  | 226 | 		}
 | 
        
           |  |  | 227 | 		if (strrpos($this->requete_champ, ', num_type') === false) {
 | 
        
           |  |  | 228 | 			$this->requete_champ .= ', num_type ';
 | 
        
           |  |  | 229 | 		}
 | 
        
           |  |  | 230 | 		$this->requete_condition[0] = 'num_nom_retenu = '.
 | 
        
           |  |  | 231 | 			'(SELECT num_nom_retenu FROM '.$this->table.' WHERE '.$this->requete_condition[0].')';
 | 
        
           |  |  | 232 | 	}
 | 
        
           |  |  | 233 |   | 
        
           |  |  | 234 | 	public function traiterRessourceIdHomonymie() {
 | 
        
           |  |  | 235 | 		// SELECT num_nom, nom_sci, num_nom_retenu FROM bdtfx_v2_00 WHERE nom_sci = (SELECT nom_sci FROM bdtfx_v2_00 WHERE num_nom = X);
 | 
        
           |  |  | 236 | 		$this->format_reponse 	 .=  '/homonymie';
 | 
        
           |  |  | 237 | 		$this->requete_condition[0] =  'nom_sci = (SELECT nom_sci FROM '.$this->table
 | 
        
           |  |  | 238 | 									.' WHERE '.$this->requete_condition[0].')';
 | 
        
           |  |  | 239 | 	}
 | 
        
           |  |  | 240 |   | 
        
           |  |  | 241 | 	public function traiterRessourceIdFlores() {
 | 
        
           |  |  | 242 | 		$champ_flores = '';
 | 
        
           |  |  | 243 | 		foreach ($this->champs_table as $champ) {
 | 
        
           |  |  | 244 | 			if (preg_match('/^flore_.*$/', $champ)) {
 | 
        
           |  |  | 245 | 				$champ_flores .= ', '.$champ;
 | 
        
           |  |  | 246 | 			}
 | 
        
           |  |  | 247 | 		}
 | 
        
           |  |  | 248 | 		$this->format_reponse .=  '/flores';
 | 
        
           |  |  | 249 | 		$this->requete_champ   = 'num_nom'.$champ_flores;
 | 
        
           |  |  | 250 | 	}
 | 
        
           |  |  | 251 |   | 
        
           |  |  | 252 | 	public function traiterRessourceStatsRangs() {
 | 
        
           |  |  | 253 | 		// SELECT count(*) as nombre, rang FROM bdtfx_v2_00 [WHERE rang = 290] GROUP BY rang ORDER BY rang;
 | 
        
           |  |  | 254 | 		$this->format_reponse   .= '/rangs';
 | 
        
           |  |  | 255 | 		$this->requete_champ 	 = 'count(*) as nombre, rang ';
 | 
        
           |  |  | 256 | 		$this->requete_group_by  = ' GROUP BY rang ORDER BY rang ';
 | 
        
           |  |  | 257 | 	}
 | 
        
           |  |  | 258 |   | 
        
           |  |  | 259 | 	public function traiterRessourceStatsAnnees() {
 | 
        
           |  |  | 260 | 		// SELECT count(*) as nombre, annee FROM bdtfx_v2_00 GROUP BY annee ORDER BY annee;
 | 
        
           |  |  | 261 | 		$this->format_reponse   .= '/annees';
 | 
        
           |  |  | 262 | 		$this->requete_champ   	 = 'count(*) as nombre, annee ';
 | 
        
           |  |  | 263 | 		$this->requete_condition = null;
 | 
        
           |  |  | 264 | 		$this->requete_group_by  = ' GROUP BY annee ORDER BY annee ';
 | 
        
           |  |  | 265 | 	}
 | 
        
           |  |  | 266 |   | 
        
           |  |  | 267 | 	public function traiterRessourceStatsInitiales() {
 | 
        
           |  |  | 268 | 		// SELECT count(left( nom_sci, 2 )) as nb, rang, left(nom_sci, 2) as lettre GROUP BY rang, left(nom_sci, 2);
 | 
        
           |  |  | 269 | 		$this->format_reponse .= '/initiales';
 | 
        
           |  |  | 270 | 		$this->requete_champ   = 'count(left( nom_sci, 2 )) as nb, rang, left(nom_sci, 2) as lettre ';
 | 
        
           |  |  | 271 | 		$this->requete_group_by  = ' GROUP BY rang, left(nom_sci, 2)';
 | 
        
           |  |  | 272 | 	}
 | 
        
           |  |  | 273 |   | 
        
           |  |  | 274 |   | 
        
           |  |  | 275 |   | 
        
           |  |  | 276 | //-----------------------------FONCTIONS DASSEMBLAGE DE LA REQUETE-----------------------------------------------------
 | 
        
           |  |  | 277 |   | 
        
           |  |  | 278 | 	public function assemblerLaRequete() {
 | 
        
           |  |  | 279 | 		if ( strrpos($this->format_reponse, 'noms/stats/') === false ) {
 | 
        
           |  |  | 280 | 			$this->mettreAuFormat(); //Ds CommunNomsTaxons.php
 | 
        
           |  |  | 281 | 		}
 | 
        
           |  |  | 282 | 		$requete = 'SELECT '.$this->retournerChamps().' '.
 | 
        
           |  |  | 283 | 			"FROM {$this->table} ".
 | 
        
           |  |  | 284 | 			$this->retournerRequeteCondition().' '.
 | 
        
           |  |  | 285 | 			$this->requete_group_by.' '.
 | 
        
           |  |  | 286 | 			$this->retournerOrderBy().' '.
 | 
        
           |  |  | 287 | 			$this->formerRequeteLimite() .
 | 
        
           |  |  | 288 | 			' -- ' . __FILE__ . ':' . __LINE__ ;
 | 
        
           |  |  | 289 | 		return $requete;
 | 
        
           |  |  | 290 | 	}
 | 
        
           |  |  | 291 |   | 
        
           |  |  | 292 | 	public function retournerChamps() {
 | 
        
           |  |  | 293 | 		$sql = '';
 | 
        
           |  |  | 294 | 		if ($this->distinct) {
 | 
        
           |  |  | 295 | 			$sql .= $this->distinct.' ';
 | 
        
           |  |  | 296 | 		}
 | 
        
           |  |  | 297 | 		if ($this->requete_champ) {
 | 
        
           |  |  | 298 | 			$sql .= $this->requete_champ.' ';
 | 
        
           |  |  | 299 | 		}
 | 
        
           |  |  | 300 |   | 
        
           |  |  | 301 | 		// Champs "virtuels" pour tier sur l'ensemble des résultats
 | 
        
           |  |  | 302 | 		if (isset($this->parametres['retour.tri'])) {
 | 
        
           |  |  | 303 | 			list($champ, $ordre) = $this->decouperParametreRetourTri();
 | 
        
           |  |  | 304 | 			if ($champ == 'retenu') {
 | 
        
           |  |  | 305 | 				$sql .= ", IF(num_nom = num_nom_retenu, '0', '1') AS nom_retenu_tri ";
 | 
        
           |  |  | 306 | 			}
 | 
        
           |  |  | 307 | 		}
 | 
        
           |  |  | 308 |   | 
        
           |  |  | 309 | 		return $sql;
 | 
        
           |  |  | 310 | 	}
 | 
        
           |  |  | 311 |   | 
        
           |  |  | 312 | 	public function decouperParametreRetourTri() {
 | 
        
           |  |  | 313 | 		$tri = array('', '');
 | 
        
           |  |  | 314 | 		if (isset($this->parametres['retour.tri'])) {
 | 
        
           |  |  | 315 | 			if (preg_match('/^(retenu)(?:,(ASC|DESC)|)$/', $this->parametres['retour.tri'], $match))
 | 
        
           |  |  | 316 | 			$tri[0] = $match[1];
 | 
        
           |  |  | 317 | 			$tri[1] = isset($match[2]) ? $match[2] : '';
 | 
        
           |  |  | 318 | 		}
 | 
        
           |  |  | 319 | 		return $tri;
 | 
        
           |  |  | 320 | 	}
 | 
        
           |  |  | 321 |   | 
        
           |  |  | 322 | 	public function retournerRequeteCondition() {
 | 
        
           |  |  | 323 | 		$condition = '';
 | 
        
           |  |  | 324 | 		if ($this->requete_condition) {
 | 
        
           |  |  | 325 | 			$condition = ' WHERE '.implode(' AND ', $this->requete_condition);
 | 
        
           |  |  | 326 | 		}
 | 
        
           |  |  | 327 | 		return $condition;
 | 
        
           |  |  | 328 | 	}
 | 
        
           |  |  | 329 |   | 
        
           |  |  | 330 | 	public function retournerOrderBy() {
 | 
        
           |  |  | 331 | 		$orderBy = array();
 | 
        
           |  |  | 332 |   | 
        
           |  |  | 333 | 		// Tri sur l'ensemble des résultats
 | 
        
           |  |  | 334 | 		if (isset($this->parametres['retour.tri'])) {
 | 
        
           |  |  | 335 | 			list($champ, $ordre) = $this->decouperParametreRetourTri();
 | 
        
           |  |  | 336 | 			if ($champ == 'retenu') {
 | 
        
           |  |  | 337 | 				$orderBy[] = "nom_retenu_tri $ordre";
 | 
        
           |  |  | 338 | 			}
 | 
        
           |  |  | 339 | 		}
 | 
        
           |  |  | 340 | 		// Tri par défaut
 | 
        
           |  |  | 341 | 		if ($this->format_reponse == 'noms') {
 | 
        
           |  |  | 342 | 			$orderBy[] = 'nom_sci ASC';
 | 
        
           |  |  | 343 | 		}
 | 
        
           |  |  | 344 |   | 
        
           |  |  | 345 | 		$sql = '';
 | 
        
           |  |  | 346 | 		if (count($orderBy) > 0) {
 | 
        
           |  |  | 347 | 			$sql = 'ORDER BY '.implode(', ', $orderBy).' ';
 | 
        
           |  |  | 348 | 		}
 | 
        
           |  |  | 349 | 		return $sql;
 | 
        
           |  |  | 350 | 	}
 | 
        
           |  |  | 351 |   | 
        
           |  |  | 352 | 	public function formerRequeteLimite() {
 | 
        
           |  |  | 353 | 		if ($this->format_reponse != 'noms' && $this->format_reponse != 'noms/id/relations/synonymie'
 | 
        
           |  |  | 354 | 				&& $this->format_reponse != 'noms/id/relations/homonymie') {
 | 
        
           |  |  | 355 | 			$this->requete_limite = '';
 | 
        
           |  |  | 356 | 		} elseif (($depart = $this->limite_requete['depart']) > ($this->total_resultat = $this->recupererTotalResultat())) {
 | 
        
           |  |  | 357 | 			$this->limite_requete['depart'] =
 | 
        
           |  |  | 358 | 			(($this->total_resultat - $this->limite_requete['limite']) < 0) ? 0 : ($this->total_resultat - $this->limite_requete['limite']);
 | 
        
           |  |  | 359 | 			$this->requete_limite = ' LIMIT '.$this->limite_requete['depart'].', '.$this->limite_requete['limite'];
 | 
        
           |  |  | 360 | 		} else {
 | 
        
           |  |  | 361 | 			$this->requete_limite = ' LIMIT '.$this->limite_requete['depart'].', '.$this->limite_requete['limite'];
 | 
        
           |  |  | 362 | 		}
 | 
        
           |  |  | 363 | 		return $this->requete_limite;
 | 
        
           |  |  | 364 | 	}
 | 
        
           |  |  | 365 |   | 
        
           |  |  | 366 | 	/** Recupere le nombre total de résultat d'une requete lancée. */
 | 
        
           |  |  | 367 | 	public function recupererTotalResultat() {
 | 
        
           |  |  | 368 | 		$total = null;
 | 
        
           |  |  | 369 | 		$requete = 'SELECT count(*) as nombre FROM '.$this->table.$this->retournerRequeteCondition().$this->requete_group_by;
 | 
        
           |  |  | 370 | 		$res = $this->getBdd()->recuperer($requete);
 | 
        
           |  |  | 371 | 		if ($res) {
 | 
        
           |  |  | 372 | 			$total = $res['nombre'];
 | 
        
           |  |  | 373 | 		} else {
 | 
        
           |  |  | 374 | 			$e = 'Fct recupererTotalResultat() : <br/>Données introuvables dans la base';
 | 
        
           |  |  | 375 | 			$this->renvoyerErreur(RestServeur::HTTP_CODE_RESSOURCE_INTROUVABLE, $e);
 | 
        
           |  |  | 376 | 		}
 | 
        
           |  |  | 377 | 		return $total;
 | 
        
           |  |  | 378 | 	}
 | 
        
           |  |  | 379 |   | 
        
           |  |  | 380 |   | 
        
           |  |  | 381 | //-------------------FONCTIONS POUR LE FORMATAGE EN JSON----------------------------------------------------------------
 | 
        
           |  |  | 382 |   | 
        
           |  |  | 383 | 	public function retournerResultatFormate($resultat) {
 | 
        
           |  |  | 384 |   | 
        
           |  |  | 385 | 		switch ($this->format_reponse) {
 | 
        
           |  |  | 386 | 			case 'noms/relations' :
 | 
        
           |  |  | 387 | 				$reponse = $this->formaterRelations($resultat[0]);
 | 
        
           |  |  | 388 | 				break;
 | 
        
           |  |  | 389 | 			case 'noms/id' : //ds CommunNomsTaxons
 | 
        
           |  |  | 390 | 				$reponse = $this->formaterId($resultat[0]);
 | 
        
           |  |  | 391 | 				break;
 | 
        
           |  |  | 392 | 			case 'noms/id/relations' :
 | 
        
           |  |  | 393 | 				$reponse = $this->formaterIdRelations($resultat[0]);
 | 
        
           |  |  | 394 | 				break;
 | 
        
           |  |  | 395 | 			case 'noms/id/relations/synonymie' :
 | 
        
           |  |  | 396 | 				$reponse = $this->formaterIdSynonymie($resultat);
 | 
        
           |  |  | 397 | 				break;
 | 
        
           |  |  | 398 | 			case 'noms/id/relations/homonymie' :
 | 
        
           |  |  | 399 | 				$reponse = $this->formaterIdHomonymie($resultat);
 | 
        
           |  |  | 400 | 				break;
 | 
        
           |  |  | 401 | 			case 'noms/id/relations/flores' : //ds CommunsNomsTaxons
 | 
        
           |  |  | 402 | 				$reponse = $this->formaterIdFlores($resultat[0]);
 | 
        
           |  |  | 403 | 				break;
 | 
        
           |  |  | 404 | 			case 'noms/stats/annees' : //ds CommunNomsTaxons
 | 
        
           |  |  | 405 | 				$reponse = $this->formaterStatsAnnee($resultat);
 | 
        
           |  |  | 406 | 				break;
 | 
        
           |  |  | 407 | 			case 'noms/stats/rangs' : //ds CommunNomsTaxons
 | 
        
           |  |  | 408 | 				$reponse = $this->formaterStatsRang($resultat);
 | 
        
           |  |  | 409 | 				break;
 | 
        
           |  |  | 410 | 			case 'noms/stats/initiales' : //ds CommunNomsTaxons
 | 
        
           |  |  | 411 | 				$reponse = $this->formaterStatsInitiales($resultat);
 | 
        
           |  |  | 412 | 				break;
 | 
        
           |  |  | 413 | 			case 'noms' :
 | 
        
           |  |  | 414 | 				$reponse = $this->formaterNoms($resultat);
 | 
        
           |  |  | 415 | 				break;
 | 
        
           |  |  | 416 | 		}
 | 
        
           |  |  | 417 | 		return $reponse;
 | 
        
           |  |  | 418 | 	}
 | 
        
           |  |  | 419 |   | 
        
           |  |  | 420 | //+---------------------concerne les resultats pour des requetes de type noms/id-----------------------------+
 | 
        
           |  |  | 421 |   | 
        
           |  |  | 422 | 	public function formaterRelations($resultat) {
 | 
        
           |  |  | 423 | 		$num_nom = $resultat['num_nom'];
 | 
        
           |  |  | 424 | 		if (isset($this->ressources[3])) {
 | 
        
           |  |  | 425 | 			$url = Config::get('url_service').$this->service."/$num_nom/relations";
 | 
        
           |  |  | 426 | 		} else {
 | 
        
           |  |  | 427 | 			$type = $this->ressources[3];
 | 
        
           |  |  | 428 | 			$url = Config::get('url_service')."/$this->service/$num_nom/relations/$type";
 | 
        
           |  |  | 429 | 		}
 | 
        
           |  |  | 430 | 		$res = $this->consulterHref($url);
 | 
        
           |  |  | 431 | 		return $res;
 | 
        
           |  |  | 432 | 	}
 | 
        
           |  |  | 433 |   | 
        
           |  |  | 434 | 	public function formaterIdRelations($resultat) {
 | 
        
           |  |  | 435 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp');
 | 
        
           |  |  | 436 | 		$this->resultat_req = $resultat;
 | 
        
           |  |  | 437 | 		$retour_id_rel = array ('entete' => array()); //on initialise pr que l'entete apparaisse en premier lors de l'affichage
 | 
        
           |  |  | 438 |   | 
        
           |  |  | 439 | 		//on recupère le resultat de chaque relation (appel du WS correspondant)
 | 
        
           |  |  | 440 | 		$flores = $this->ajouterRelations('flores');
 | 
        
           |  |  | 441 | 		if (isset($flores)) $retour_id_rel['resultat']['flores'] = $flores;
 | 
        
           |  |  | 442 | 		$homonymes = $this->ajouterRelations('homonymie');
 | 
        
           |  |  | 443 | 		if (isset($homonymes)) $retour_id_rel['resultat']['homonymes'] = $homonymes;
 | 
        
           |  |  | 444 | 		$synonymes = $this->ajouterRelations('synonymie');
 | 
        
           |  |  | 445 | 		if (isset($synonymes)) $retour_id_rel['resultat']['synonymes'] = $synonymes;
 | 
        
           |  |  | 446 |   | 
        
           |  |  | 447 | 		//on renvoit null si il n'existe aucune relations (on efface l'entete en premier lieu)
 | 
        
           |  |  | 448 | 		if (!isset($retour_id_rel['resultat']))	{
 | 
        
           |  |  | 449 | 			$retour_id_rel = null;
 | 
        
           |  |  | 450 | 		} else { //on rajoute l'entete si des relations existent
 | 
        
           |  |  | 451 | 			$this->afficherDonnees('num_nom', $this->ressources[0]);
 | 
        
           |  |  | 452 | 			$retour_id_rel['entete'] = $this->table_retour;
 | 
        
           |  |  | 453 | 			$this->table_retour = array();
 | 
        
           |  |  | 454 | 		}
 | 
        
           |  |  | 455 | 		return $retour_id_rel;
 | 
        
           |  |  | 456 | 	}
 | 
        
           |  |  | 457 |   | 
        
           |  |  | 458 | 	/**
 | 
        
           |  |  | 459 | 	 * Recupere les relations (type de la relation passée en paramètres :[type_relation] = synonymie, homonymie ou
 | 
        
           |  |  | 460 | 	 * flores) par l'appel du web service [version]/noms/#id/relations/[type_relation]
 | 
        
           |  |  | 461 | 	 */
 | 
        
           |  |  | 462 | 	public function ajouterRelations($relation) {
 | 
        
           |  |  | 463 | 		$version = str_replace(Config::get('bdd_table').'_', '', $this->table);
 | 
        
           |  |  | 464 | 		$res = null;
 | 
        
           |  |  | 465 | 		$parametres_url = '';
 | 
        
           |  |  | 466 | 		if ($this->parametres != array()) $parametres_url = '?'.http_build_query($this->parametres, '', '&');
 | 
        
           |  |  | 467 | 		$url = Config::get('url_service').'/'.$this->service.'/'
 | 
        
           |  |  | 468 | 									.$this->ressources[0].'/relations/'
 | 
        
           |  |  | 469 | 									.$relation.$parametres_url;	Debug::printr($url);
 | 
        
           |  |  | 470 |   | 
        
           |  |  | 471 | 		$relation = $this->consulterHref($url);
 | 
        
           |  |  | 472 |   | 
        
           |  |  | 473 | 		$res = $relation->resultat;
 | 
        
           |  |  | 474 | 		return $res;
 | 
        
           |  |  | 475 | 	}
 | 
        
           |  |  | 476 |   | 
        
           |  |  | 477 |   | 
        
           |  |  | 478 | 	public function formaterIdSynonymie($resultat) {
 | 
        
           |  |  | 479 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp');
 | 
        
           |  |  | 480 | 		$retour_id_syn = array();
 | 
        
           |  |  | 481 | 		if ($resultat[0]['num_nom_retenu'] == '') return array('nom_retenu N.D.');
 | 
        
           |  |  | 482 |   | 
        
           |  |  | 483 |         // 1 ou + résultat(s)
 | 
        
           |  |  | 484 |         $retour_id_syn['entete'] = $this->afficherEnteteResultat('/'.$this->service.'/'.$this->ressources[0].'/relations/synonymie');
 | 
        
           |  |  | 485 |         $retour_id_syn['entete']['id'] = $this->ressources[0];
 | 
        
           |  |  | 486 |         $retour_id_syn['resultat'] = array();
 | 
        
           |  |  | 487 |   | 
        
           |  |  | 488 |         // résultat contient aussi l'original
 | 
        
           |  |  | 489 |         if(count($resultat) > 1) {
 | 
        
           |  |  | 490 | 			//on remplit d'abord l'entete du resultat
 | 
        
           |  |  | 491 | 			$this->table_retour['id'] = $this->ressources[0];
 | 
        
           |  |  | 492 | 			$this->afficherEnteteResultat('/'.$this->service.'/'.$this->ressources[0].'/relations/synonymie');
 | 
        
           |  |  | 493 | 			$retour_id_syn['entete'] = $this->table_retour;
 | 
        
           |  |  | 494 | 			$this->table_retour = array();
 | 
        
           |  |  | 495 | 			foreach ($resultat as $tab) {
 | 
        
           |  |  | 496 | 				//pour chaque basionyme, on recupère le résultat : num_nom, nom_sci, num_basionyme et num_nom_retenu :
 | 
        
           |  |  | 497 | 				$this->resultat_req = $tab;
 | 
        
           |  |  | 498 | 				$num = $tab['num_nom'];
 | 
        
           |  |  | 499 | 				$this->afficherNomHrefRetenu($tab, $num);
 | 
        
           |  |  | 500 | 				$this->afficherDonnees('num_basionyme', $tab['num_basionyme']);
 | 
        
           |  |  | 501 | 				$this->afficherDonnees('num_type', $tab['num_type']);
 | 
        
           |  |  | 502 | 				$this->afficherDonnees('num_type', $tab['num_type']);
 | 
        
           |  |  | 503 | 				$retour_id_syn['resultat'][$num] = $this->table_retour;
 | 
        
           |  |  | 504 | 				$this->table_retour = array();
 | 
        
           |  |  | 505 | 			}
 | 
        
           |  |  | 506 | 			if (!isset($retour_id_syn['resultat']) && !in_array('nom_retenu N.D.', $retour_id_syn)) {
 | 
        
           |  |  | 507 | 				$retour_id_syn = null; //on initialise le resultat à null
 | 
        
           |  |  | 508 | 			}
 | 
        
           |  |  | 509 | 		}
 | 
        
           |  |  | 510 | 		return $retour_id_syn;
 | 
        
           |  |  | 511 | 	}
 | 
        
           |  |  | 512 |   | 
        
           |  |  | 513 | 	public function formaterIdHomonymie($resultat) {
 | 
        
           |  |  | 514 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp');
 | 
        
           |  |  | 515 | 		if (count($resultat) != 1) {
 | 
        
           |  |  | 516 | 			$this->table_retour['id'] = $this->ressources[0];
 | 
        
           |  |  | 517 | 			$this->afficherEnteteResultat($resultat, '/'.$this->service.'/'.$this->ressources[0].'/relations/homonymie');
 | 
        
           |  |  | 518 | 			$retour_id_hom['entete'] = $this->table_retour;
 | 
        
           |  |  | 519 | 			$this->table_retour = array();
 | 
        
           |  |  | 520 | 			foreach ($resultat as $homonyme) {
 | 
        
           |  |  | 521 | 				$this->resultat_req = $homonyme;
 | 
        
           |  |  | 522 | 				$id = $homonyme['num_nom'];
 | 
        
           |  |  | 523 | 				$this->afficherDonnees('num_nom', $id);
 | 
        
           |  |  | 524 | 				if ($homonyme['num_nom_retenu'] != '') {
 | 
        
           |  |  | 525 | 					$retenu = ($id == $homonyme['num_nom_retenu']) ? 'true' : 'false';
 | 
        
           |  |  | 526 | 				} else {
 | 
        
           |  |  | 527 | 					$retenu = 'absent';
 | 
        
           |  |  | 528 | 				}
 | 
        
           |  |  | 529 | 				$this->table_retour['retenu'] = $retenu;
 | 
        
           |  |  | 530 | 				$retour_id_hom['resultat'][$id] = $this->table_retour;
 | 
        
           |  |  | 531 | 				unset($retour_id_hom['resultat'][$id]['id']);
 | 
        
           |  |  | 532 | 				$this->table_retour = array();
 | 
        
           |  |  | 533 | 			}
 | 
        
           |  |  | 534 | 		} else {
 | 
        
           |  |  | 535 | 			$retour_id_hom = null;
 | 
        
           |  |  | 536 | 		}
 | 
        
           |  |  | 537 | 		return $retour_id_hom;
 | 
        
           |  |  | 538 | 	}
 | 
        
           |  |  | 539 |   | 
        
           |  |  | 540 | 	public function obtenirSynonymesParNumNomAvecInfosFlore($num_nom, $version='1_02') {
 | 
        
           |  |  | 541 |   | 
        
           |  |  | 542 | 		$champs_flore = 'flore_bonnier_num, flore_bonnier_rem,'.
 | 
        
           |  |  | 543 | 						'flore_cnrs_num, flore_cnrs_rem '.
 | 
        
           |  |  | 544 | 						'flore_fe_num, flore_fe_rem '.
 | 
        
           |  |  | 545 | 						'flore_coste_num, flore_coste_rem '.
 | 
        
           |  |  | 546 | 						'flore_fh_num, flore_fh_rem '.
 | 
        
           |  |  | 547 | 						'flore_fournier_num, flore_fournier_rem';
 | 
        
           |  |  | 548 |   | 
        
           |  |  | 549 | 		$requete = 'SELECT num_nom, nom_sci, '.$champs_flore.' '.
 | 
        
           |  |  | 550 | 						'FROM '.$this->table.' '.
 | 
        
           |  |  | 551 | 						'WHERE num_nom_retenu = '.
 | 
        
           |  |  | 552 | 						'('.
 | 
        
           |  |  | 553 | 						'SELECT num_nom_retenu FROM '.$this->table.' WHERE num_nom = "'.$num_nom.'"'.
 | 
        
           |  |  | 554 | 						')';
 | 
        
           |  |  | 555 |   | 
        
           |  |  | 556 | 		return $this->getBdd()->recupererTous($requete . ' -- ' . __FILE__ . ':' . __LINE__ );
 | 
        
           |  |  | 557 | 	}
 | 
        
           |  |  | 558 |   | 
        
           |  |  | 559 | 	public function formaterIdFlores($resultat) {
 | 
        
           |  |  | 560 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp,noms_projets');
 | 
        
           |  |  | 561 | 		$this->resultat_req = $resultat;
 | 
        
           |  |  | 562 | 		$id = array_shift($resultat);
 | 
        
           |  |  | 563 | 		$reponse['entete']['id'] = $id;
 | 
        
           |  |  | 564 | 		$synonymes_flores = $this->obtenirSynonymesParNumNomAvecInfosFlore($this->ressources[0]);
 | 
        
           |  |  | 565 | 		if(is_array($synonymes_flores)) {
 | 
        
           |  |  | 566 | 			foreach ($synonymes_flores as $synonyme) {
 | 
        
           |  |  | 567 | 				$nom_sci = $synonyme['nom_sci'];
 | 
        
           |  |  | 568 | 				$num_nom = $synonyme['num_nom'];
 | 
        
           |  |  | 569 | 				unset($synonyme['nom_sci']);
 | 
        
           |  |  | 570 | 				unset($synonyme['num_nom']);
 | 
        
           |  |  | 571 | 				foreach ($synonyme as $flores => $valeur) {
 | 
        
           |  |  | 572 | 					if ($valeur != '' && $valeur != '0') {
 | 
        
           |  |  | 573 | 						$this->afficherInfosFlore($synonyme, $flores, $valeur, $nom_sci, $num_nom);
 | 
        
           |  |  | 574 | 					}
 | 
        
           |  |  | 575 | 				}
 | 
        
           |  |  | 576 | 			}
 | 
        
           |  |  | 577 | 		}
 | 
        
           |  |  | 578 |   | 
        
           |  |  | 579 | 		if ($this->table_retour != array()) {
 | 
        
           |  |  | 580 | 			$reponse['resultat'] = $this->table_retour;
 | 
        
           |  |  | 581 | 			$this->table_retour = array();
 | 
        
           |  |  | 582 | 		} else {
 | 
        
           |  |  | 583 | 			$reponse = null;
 | 
        
           |  |  | 584 | 		}
 | 
        
           |  |  | 585 | 		return $reponse;
 | 
        
           |  |  | 586 | 	}
 | 
        
           |  |  | 587 |   | 
        
           |  |  | 588 | 	public function getNomCompletFlore($flore) {
 | 
        
           |  |  | 589 | 		return Config::get($flore.'_texte');
 | 
        
           |  |  | 590 | 	}
 | 
        
           |  |  | 591 |   | 
        
           |  |  | 592 | 	public function afficherInfosFlore(&$resultat, $flores, $valeur, $nom_sci, $num_nom) {
 | 
        
           |  |  | 593 | 		$flore = substr($flores,0,strrpos($flores, '_'));
 | 
        
           |  |  | 594 | 		$projet = $this->noms_projets[$flore];
 | 
        
           |  |  | 595 |   | 
        
           |  |  | 596 | 		//TODO voir si l'on peut factoriser les affectations à la table retour
 | 
        
           |  |  | 597 | 		// et simplifier ce gros pavé
 | 
        
           |  |  | 598 | 		if (strrpos($flores, 'num') !== false) {
 | 
        
           |  |  | 599 | 			if (preg_match('/^([0-9]+)(?:[.]syn[^a-z]*|(.*))?$/', $valeur, $match)) {
 | 
        
           |  |  | 600 | 				$this->table_retour[$num_nom][$flore]['id'] = $match[1];
 | 
        
           |  |  | 601 | 				if ($projet == 'coste') {
 | 
        
           |  |  | 602 | 					$this->table_retour[$num_nom][$flore]['href'] = $this->ajouterHrefAutreProjet('noms', 'nn_coste:', $match[1], $projet);
 | 
        
           |  |  | 603 | 				}
 | 
        
           |  |  | 604 | 				if (isset($match[2]) && $match[2] != '') $this->table_retour[$num_nom][$flore]['cle'] = $match[2];
 | 
        
           |  |  | 605 | 				$this->table_retour[$num_nom][$flore]['nom_flore'] = $this->getNomCompletFlore($flore);
 | 
        
           |  |  | 606 | 				$this->table_retour[$num_nom][$flore]['nom_sci'] = $nom_sci;
 | 
        
           |  |  | 607 | 			}
 | 
        
           |  |  | 608 | 			if (isset($resultat[$flore.'_rem']) && !empty($resultat[$flore.'_rem'])) {
 | 
        
           |  |  | 609 | 				$this->table_retour[$num_nom][$flore]['remarque'] = $resultat[$flore.'_rem'];
 | 
        
           |  |  | 610 | 				$this->table_retour[$num_nom][$flore]['nom_flore'] = $this->getNomCompletFlore($flore);
 | 
        
           |  |  | 611 | 				$this->table_retour[$num_nom][$flore]['nom_sci'] = $nom_sci;
 | 
        
           |  |  | 612 | 				unset($resultat[$flore.'_rem']);
 | 
        
           |  |  | 613 | 			}
 | 
        
           |  |  | 614 | 		} elseif (strrpos($flores,'belge') !== false) {
 | 
        
           |  |  | 615 | 			if (preg_match('/^([0-9]+) (R|S)?$/', $valeur, $match)) {
 | 
        
           |  |  | 616 | 				if (isset($match[2])) $type = ($match[2] == 'R') ? 'taxons' : 'synonyme';
 | 
        
           |  |  | 617 | 				$this->table_retour[$num_nom][$flore]['page'] = $match[1];
 | 
        
           |  |  | 618 | 				$this->table_retour[$num_nom][$flore]['type'] = $type;
 | 
        
           |  |  | 619 | 				$this->table_retour[$num_nom][$flore]['nom_flore'] = $this->getNomCompletFlore($flore);
 | 
        
           |  |  | 620 | 				$this->table_retour[$num_nom][$flore]['nom_sci'] = $nom_sci;
 | 
        
           |  |  | 621 | 			}
 | 
        
           |  |  | 622 | 		}
 | 
        
           |  |  | 623 | 	}
 | 
        
           |  |  | 624 |   | 
        
           |  |  | 625 | //+---------------------concerne les resultats pour des requetes de type /noms avec ou sans paramètres-------+
 | 
        
           |  |  | 626 |   | 
        
           |  |  | 627 | 	public function formaterNoms($resultat) {
 | 
        
           |  |  | 628 | 		if ($this->parametres['retour.format'] == 'oss') {
 | 
        
           |  |  | 629 | 			$reponse = $this->formaterEnOss($resultat);	 //Ds CommunNomsTaxons.php
 | 
        
           |  |  | 630 | 		} else {
 | 
        
           |  |  | 631 | 			$reponse = $this->formaterEnJsonMax($resultat);
 | 
        
           |  |  | 632 | 		}
 | 
        
           |  |  | 633 | 		return $reponse;
 | 
        
           |  |  | 634 | 	}
 | 
        
           |  |  | 635 |   | 
        
           |  |  | 636 | 	public function formaterEnJsonMax($resultat) {
 | 
        
           |  |  | 637 | 		$this->recupererTableSignification('correspondance_champs,champs_api,champs_comp');
 | 
        
           |  |  | 638 |   | 
        
           |  |  | 639 | 		// TODO : améliorer le tri des résultats
 | 
        
           |  |  | 640 | 		// ATTENTION : ce comportement est étrange
 | 
        
           |  |  | 641 | 		$masque = $this->recupererMasquePrincipal();
 | 
        
           |  |  | 642 | 		if ($masque && isset($this->parametres[$masque[0]] /* à éclaircir */ ) && !isset($this->parametres['retour.tri'])) {
 | 
        
           |  |  | 643 | 			$resultat = $this->trierRechercheFloue($this->parametres[$masque[0]], $resultat, $masque[1]);
 | 
        
           |  |  | 644 | 		}
 | 
        
           |  |  | 645 |   | 
        
           |  |  | 646 | 		// Tri à la mode du CeL : lexicographique puis noms retenus (retour.tri = "alpharet")
 | 
        
           |  |  | 647 | 		if (isset($this->parametres['retour.tri']) && ($this->parametres['retour.tri'] == "alpharet")) {
 | 
        
           |  |  | 648 | 			usort($resultat, array($this, 'genrePuisNomsRetenusEnTete'));
 | 
        
           |  |  | 649 | 		}
 | 
        
           |  |  | 650 |   | 
        
           |  |  | 651 | 		$table_retour_json['entete'] = $this->afficherEnteteResultat('/'.$this->service);
 | 
        
           |  |  | 652 | 		$table_retour_json['resultat'] = $this->remplirJsonResultat($resultat);
 | 
        
           |  |  | 653 | 		return $table_retour_json;
 | 
        
           |  |  | 654 | 	}
 | 
        
           |  |  | 655 |   | 
        
           |  |  | 656 | 	// Trie les éléments du tableau de résultats : le genre en tête, puis les noms retenus, puis le reste
 | 
        
           |  |  | 657 | 	// mais à partir du jeu de données retourné par SQL (indépendents du statut "retenu")
 | 
        
           |  |  | 658 | 	private function genrePuisNomsRetenusEnTete($a, $b) {
 | 
        
           |  |  | 659 | 		// On pourrait utiliser l'indice ['retenu'] mais il contient parfois "absent", qui est dur à traiter
 | 
        
           |  |  | 660 | 		$aEstRetenu = ($a['num_nom'] == $a['num_nom_retenu']);
 | 
        
           |  |  | 661 | 		$bEstRetenu = ($b['num_nom'] == $b['num_nom_retenu']);
 | 
        
           |  |  | 662 | 		$retour = 0;
 | 
        
           |  |  | 663 |   | 
        
           |  |  | 664 | 		// les noms retenus en premier ("inférieurs")
 | 
        
           |  |  | 665 | 		if ($aEstRetenu) {
 | 
        
           |  |  | 666 | 			if (! $bEstRetenu) {
 | 
        
           |  |  | 667 | 				$retour = -1;
 | 
        
           |  |  | 668 | 			}
 | 
        
           |  |  | 669 | 		}  else {
 | 
        
           |  |  | 670 | 			if ($bEstRetenu) {
 | 
        
           |  |  | 671 | 				$retour = 1;
 | 
        
           |  |  | 672 | 			}
 | 
        
           |  |  | 673 | 		}
 | 
        
           |  |  | 674 |   | 
        
           |  |  | 675 | 		// en cas d'égalité on conserve le tri lexicographique - devrait faire sortir le genre en première position
 | 
        
           |  |  | 676 | 		// car il ne contient pas le nom d'auteur
 | 
        
           |  |  | 677 | 		if ($retour == 0) {
 | 
        
           |  |  | 678 | 			$retour = strcasecmp($a['nom_sci'], $b['nom_sci']);
 | 
        
           |  |  | 679 | 		}
 | 
        
           |  |  | 680 |   | 
        
           |  |  | 681 | 		return $retour;
 | 
        
           |  |  | 682 | 	}
 | 
        
           |  |  | 683 |   | 
        
           |  |  | 684 | 	public function remplirJsonResultat($resultat) {
 | 
        
           |  |  | 685 | 		$champs = null;
 | 
        
           |  |  | 686 | 		if (array_key_exists('retour.champs', $this->parametres)) {
 | 
        
           |  |  | 687 | 			$champs = explode(',', $this->parametres['retour.champs']);
 | 
        
           |  |  | 688 | 		}
 | 
        
           |  |  | 689 |   | 
        
           |  |  | 690 | 		// Structure des données: objet ou liste ?
 | 
        
           |  |  | 691 | 		$modeListe = false;
 | 
        
           |  |  | 692 | 		if (array_key_exists('retour.structure', $this->parametres)) {
 | 
        
           |  |  | 693 | 			$modeListe = ($this->parametres['retour.structure'] === "liste");
 | 
        
           |  |  | 694 | 		}
 | 
        
           |  |  | 695 |   | 
        
           |  |  | 696 | 		$noms = array();
 | 
        
           |  |  | 697 | 		foreach ($resultat as $tab) {
 | 
        
           |  |  | 698 | 			$this->table_retour = array();
 | 
        
           |  |  | 699 | 			$num = $tab['num_nom'];
 | 
        
           |  |  | 700 | 			$this->afficherNomHrefRetenu($tab, $num); // ajoute le nom_sci, href et si le nom est retenu dans $this->table_retour
 | 
        
           |  |  | 701 | 			$retour = $this->table_retour;
 | 
        
           |  |  | 702 | 			$this->table_retour = array();
 | 
        
           |  |  | 703 | 			if ($champs != null) {
 | 
        
           |  |  | 704 | 				$reponse_id = $this->formaterId($tab);
 | 
        
           |  |  | 705 | 				$this->table_retour = array();
 | 
        
           |  |  | 706 | 				$this->ajouterChampsPersonnalises($champs, $reponse_id);
 | 
        
           |  |  | 707 | 				$retour = array_merge($retour, $this->table_retour);
 | 
        
           |  |  | 708 | 			}
 | 
        
           |  |  | 709 | 			if ($modeListe) {
 | 
        
           |  |  | 710 | 				$retour['num_nom'] = intval($num);
 | 
        
           |  |  | 711 | 				$noms[] = $retour;
 | 
        
           |  |  | 712 | 			} else {
 | 
        
           |  |  | 713 | 				$noms[$num] = $retour;
 | 
        
           |  |  | 714 | 			}
 | 
        
           |  |  | 715 | 		}
 | 
        
           |  |  | 716 |   | 
        
           |  |  | 717 | 		return  $noms;
 | 
        
           |  |  | 718 | 	}
 | 
        
           |  |  | 719 | }
 | 
        
           |  |  | 720 | ?>
 |