New file |
0,0 → 1,215 |
<?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.org |
private 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 proposition |
|
if (!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érence |
if (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); |
} |
} |
?> |