Rev 924 | Rev 1251 | 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->conteneur->chargerConfiguration('config_mapping_commentaires.ini');$this->navigation = $conteneur->getNavigation();$this->masque = $conteneur->getMasque();$this->gestionBdd = $conteneur->getGestionBdd();$this->bdd = $this->gestionBdd->getBdd();}/*** Ajoute un commentaire/determination si les objets fournis en paramètres sont valides* 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();$insertion = $this->insererCommentaire($utilisateur);// Mettre en forme le résultat et l'envoyer pour affichage$resultat = new ResultatService();$resultat->corps = array('id_commentaire' => $insertion);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();if (empty($this->mappingCommentaire)) {$erreurs[] = '- le fichier de configuration ne contient pas le tableau [mapping_commentaire] ou celui-ci est vide ;';} else {$champsMappingCom = array('id_commentaire', 'texte', 'ce_utilisateur', 'utilisateur_nom', 'utilisateur_prenom', 'utilisateur_courriel', 'date');foreach ($champsMappingCom as $champ) {if (!isset($this->mappingCommentaire[$champ])) {$erreurs[] = '- le mapping du champ "'.$champ.'" pour le commentaire est manquant ;';}}}$parametresPossibles = array('observation', 'proposition', 'id_parent', 'texte', 'auteur.id','auteur.prenom', 'auteur.nom', 'auteur.courriel', '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['auteur.id'])) {if (!isset($this->parametres['auteur.nom'])) {$erreurs[] = ' - pas de nom donné ;';}if (!isset($this->parametres['auteur.prenom'])) {$erreurs[] = ' - pas de prenom donné; ';}if (!isset($this->parametres['auteur.courriel'])) {$erreurs[] = ' - pas de courriel donné;';}}if (isset($this->parametres['nom_sel']) &&trim($this->parametres['nom_sel']) == '') {$erreurs[] = ' - S\'il est présent le paramètre nom_sel ne peut pas être vide ;';}//TODO : Gérer le cas d'une propositionif (!empty($erreurs)) {$e = 'Erreur de configuration :';$e = implode("\n", $erreurs);echo var_dump($e);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['auteur.id'])) {$requete = "SELECT id_utilisateur as 'auteur.id', nom as 'auteur.nom', prenom as 'auteur.prenom', courriel as 'auteur.courriel' ".'FROM '.$this->gestionBdd->formaterTable('del_utilisateur').'WHERE id_utilisateur = '.$this->bdd->proteger($this->parametres['auteur.id']);$utilisateur = $this->bdd->recuperer($requete);} else {if (isset($this->parametres['auteur.nom']) && isset($this->parametres['auteur.prenom']) && isset($this->parametres['auteur.courriel'])) {$utilisateur['auteur.nom'] = $this->parametres['auteur.nom'];$utilisateur['auteur.prenom'] = $this->parametres['auteur.prenom'];$utilisateur['auteur.courriel'] = $this->parametres['auteur.courriel'];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['auteur.id'] = $utilisateur['auteur.id'];}}}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 'auteur.id', nom as 'auteur.nom', prenom as 'auteur.prenom', courriel as 'auteur.courriel' ".'FROM '.$this->gestionBdd->formaterTable('del_utilisateur').'WHERE courriel = '.$this->bdd->proteger($utilisateur['auteur.courriel']).' AND nom = '.$this->bdd->proteger($utilisateur['auteur.nom']).' AND prenom = '.$this->bdd->proteger($utilisateur['auteur.prenom']);$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);}$retour = $this->bdd->recupererIdDernierAjout();return $retour;}private function genererEntete($utilisateur) {$this->parametres = array_merge($this->parametres, $utilisateur);$entete = array();foreach ($this->mappingCommentaire as $nomOriginal => $nomFinal) {if (isset($this->parametres[$nomFinal]) && $this->parametres[$nomFinal] != null) {$entete[] = $nomOriginal;}}$entete[] = 'date';return implode(', ', $entete);}private function genererValues() {$valeurs = array();foreach ($this->mappingCommentaire as $nomOriginal => $nomFinal) {if (isset($this->parametres[$nomFinal]) && $this->parametres[$nomFinal] != null) {$valeurs[] = $this->bdd->proteger($this->parametres[$nomFinal]);}}$valeurs[] = 'NOW()';return implode(', ', $valeurs);}}?>