Rev 858 | Rev 883 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php// declare(encoding='UTF-8');/*** Le web service image récupère toutes les données de la table del_obs_images* pour retourner une liste d'images associée à une observation** @category php 5.2* @package del* @subpackage images* @author Jean-Pascal MILCENT <jpm@tela-botanica.org>* @copyright Copyright (c) 2012, Tela Botanica (accueil@tela-botanica.org)* @license http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL* @license http://www.gnu.org/licenses/gpl.html Licence GNU-GPL* @version $Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $* @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images*/class AjouterCommentaire {private $conteneur;private $navigation;private $masque;private $gestionBdd;private $bdd;private $parametres = array();private $ressources = array();private $commentaire;public function __construct(Conteneur $conteneur = null) {$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;$this->conteneur->chargerConfiguration('config_commentaires.ini');$this->navigation = $conteneur->getNavigation();$this->masque = $conteneur->getMasque();$this->gestionBdd = $conteneur->getGestionBdd();$this->bdd = $this->gestionBdd->getBdd();}/*** Méthode principale de la classe.* 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 ajouter($ressources, $parametres) {$this->initialiserRessourcesEtParametres($ressources, $parametres);// Gestion des configuration du script$this->configurer();$this->verifierConfiguration();$utilisateur = $this->chercherUtilisateur();$this->insererCommentaire($utilisateur);// Lancement du service$resultat = new ResultatService();$resultat->corps = array('entete' => $this->conteneur->getEntete(), 'resultats' => '');return $resultat;}//ce_observation=728176&texte=ABC&auteur.id=11623&auteur.prenom=grégoire&auteur.nom=duché&auteur.courriel=gregoire@tela-botanica.orgprivate function initialiserRessourcesEtParametres($ressources, $parametres) {$this->ressources = $ressources;$this->parametres = $parametres;}/*-------------------------------------------------------------------------------CONFIGURATION DU SERVICE--------------------------------------------------------------------------------*//*** Initialiser les attributs de la classe avec les parametres* */public function configurer() {$this->mappingCommentaire = $this->conteneur->getParametre('mapping_commentaire');;//TODO : Gérer le cas d'une proposition}/*** Vérifier que le service est bien configuré* */public function verifierConfiguration() {$erreurs = array();$parametresPossibles = array('observation', 'proposition', 'id_parent', 'texte', 'id_auteur','prenom_auteur', 'nom_auteur', 'courriel_auteur', 'nom_sel','nom_sel_nn', 'nom_ret', 'nom_ret_nn', 'nt', 'famille');foreach ($this->parametres as $nomParam => $valeur) {if (!in_array($nomParam, $parametresPossibles)) {$erreurs[] = ' - paramètre '.$nomParam.' non autorisé; ';}}if (!isset($this->parametres['observation'])) {$erreurs[] = ' - impossible d\'ajouter un commentaire sans observation ;';}if (!isset($this->parametres['id_auteur'])) {if (!isset($this->parametres['nom_auteur'])) {$erreurs[] = ' - pas de nom donné ;';}if (!isset($this->parametres['prenom_auteur'])) {$erreurs[] = ' - pas de prenom donné; ';}if (!isset($this->parametres['courriel_auteur'])) {$erreurs[] = ' - pas de courriel donné;';}}//TODO : Gérer le cas d'une propositionif (!empty($erreurs)) {$e = 'Erreur de configuration :';$e = implode("\n", $erreurs);throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);}}/*-------------------------------------------------------------------------------INSERTION DES COMMENTAIRES--------------------------------------------------------------------------------*//*** Trouver l'utilisateur en fonction des paramètres ou de la base de données si le nom, prénom et courriel ne sont pas donnés* @return le tableau utilisateur* */private function chercherUtilisateur() {$utilisateur = array();// Si l'id est fournit, on récupère les informations de l'utilisateur dans la base de données// Sinon, on récupère les informations depuis le tableau Commentaire et on vérifie leur cohérenceif (isset($this->parametres['id_auteur'])) {$requete = 'SELECT id_utilisateur as id_auteur, nom as nom_auteur, prenom as prenom_auteur, courriel as courriel_auteur '.'FROM '.$this->gestionBdd->formaterTable('del_utilisateur').'WHERE id_utilisateur = '.$this->parametres['id_auteur'];$utilisateur = $this->bdd->recuperer($requete);} else {if (isset($this->parametres['nom_auteur']) && isset($this->parametres['prenom_auteur']) && isset($this->parametres['courriel_auteur'])) {$utilisateur['nom_auteur'] = $this->parametres['nom_auteur'];$utilisateur['prenom_auteur'] = $this->parametres['prenom_auteur'];$utilisateur['courriel_auteur'] = $this->parametres['courriel_auteur'];if (!($utilisateur = $this->estValideDansBdd($utilisateur))) {$e = 'L\'utilisateur saisi existe déjà dans la base de données';throw new Exception($e, RestServeur::HTTP_CODE_ACCES_NON_AUTORISE);} else {$this->parametres['id_auteur'] = $utilisateur['id_auteur'];}}}return $utilisateur;}/*** Vérifier que les informations saisies pour un utilisateur sont valides pour la bdd* @param $utilisateur array le tableau de l'utilisateur* */private function estValideDansBdd($utilisateur) {$requete = 'SELECT id_utilisateur as id_auteur, nom as nom_auteur, prenom as prenom_auteur, courriel_auteur '.'FROM '.$this->gestionBdd->formaterTable('del_utilisateur').'WHERE courriel = '.$this->bdd->proteger($utilisateur['courriel_auteur']).' AND nom = '.$this->bdd->proteger($utilisateur['nom_auteur']).' AND prenom = '.$this->bdd->proteger($utilisateur['prenom_auteur']);$utilisateurBdd = $this->bdd->recuperer($requete);return $utilisateurBdd;}/*** Insère un commentaire dans la table* @param $utilisateur array la liste des paramètres utilisateur* */private function insererCommentaire($utilisateur) {$requete = 'INSERT INTO '.$this->gestionBdd->formaterTable('del_commentaire');$requete .= '('.$this->genererEntete($utilisateur).') ';$requete .= 'VALUES ('.$this->genererValues().')';$retour = $this->bdd->requeter($requete);if ($retour == null) {$e = 'Erreur inopinée lors de l\insertion';throw new Exception($e, RestServeur::HTTP_CODE_ERREUR);}}private function genererEntete($utilisateur) {$this->parametres = array_merge($this->parametres, $utilisateur);$entete = array();foreach ($this->parametres as $var => $val) {if ($val != null) {$entete[] = $this->mappingCommentaire[$var];}}return implode(', ', $entete);}private function genererValues() {$valeurs = array();foreach ($this->parametres as $var => $val) {if ($val != null) {$valeurs[] = $val;}}$valeurs = $this->bdd->protegerTableau($valeurs);return implode(', ', $valeurs);}}?>