Subversion Repositories eFlore/Applications.del

Rev

Go to most recent revision | Details | Last modification | View Log | RSS feed

Rev Author Line No. Line
1252 aurelien 1
<?php
2
// declare(encoding='UTF-8');
3
/**
4
 * Le web service récupére un identifiant de proposition et appelle un service web externe
5
 * (du cel) afin de modifier le nom de l'observation associée par celui de la proposition
6
 *
7
 * @category	php 5.2
8
 * @package	del
9
 * @subpackage images
10
 * @author		Aurélien Peronnet <aurelien@tela-botanica.org>
11
 * @copyright	Copyright (c) 2013, Tela Botanica (accueil@tela-botanica.org)
12
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
13
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
14
 * @version	$Id$
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
16
 */
17
 
18
class ValiderDetermination {
19
 
20
	private $conteneur;
21
	private $navigation;
22
	private $masque;
23
	private $gestionBdd;
24
	private $bdd;
25
	private $parametres = array();
26
	private $ressources = array();
27
 
28
	public function __construct(Conteneur $conteneur = null) {
29
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
30
		$this->conteneur->chargerConfiguration('config_determinations.ini');
31
		$this->gestionBdd = $conteneur->getGestionBdd();
32
		$this->bdd = $this->gestionBdd->getBdd();
33
	}
34
 
35
	public function modifier($ressources, $parametres) {
36
		$this->verifierParametres($ressources, $parametres);
37
		$id_proposition = $ressources[1];
38
 
1456 raphael 39
		if(! ($e = $this->modifierObservationParDetermination($id_proposition, $parametres['auteur.id'])) ) {
40
		  throw new Exception("error: Cel returned \"$e\"", RestServeur::HTTP_CODE_ERREUR);
41
		}
1444 raphael 42
		RestServeur::envoyerEnteteStatutHttp(RestServeur::HTTP_CODE_OK);
1252 aurelien 43
	}
44
 
45
	public function verifierParametres($ressources, $parametres) {
46
		$erreurs = array();
47
		if (!is_numeric($ressources[1])) {
48
			$erreurs[] = '- le paramètre indiquant l\'identifiant de la proposition doit être numérique ;';
49
		}
50
 
51
		//Le paramètre auteur.id (id de l'auteur de la détermination)
52
		// est là pour éviter que le $_POST ne soit vide
53
		if (!isset($parametres['auteur.id'])) {
54
			$erreurs[] = '- paramètre "auteur.id" manquant ;';
55
		}
56
 
1440 raphael 57
		if ($erreurs) {
58
			throw new Exception("Erreur lors de la configuration :\n" . implode("\n", $erreurs),
59
								RestServeur::HTTP_CODE_ERREUR);
1252 aurelien 60
		}
61
	}
62
 
1450 raphael 63
	/*
64
	 * 1) récupère l'observation, autrement échec
65
	 * 2) récupère et l'auteur officiel et valide l'authentification (match sur $_POST['auteur.id'] et $_SESSION), autrement échec
66
	 * 3) prépare les nouvelles valeurs à mettre à jour dans cel_obs depuis del_commentaire
67
	 * 4) effectue la mise à jour
68
	 * 5) si tout s'est passé comme convenu, marque la proposition comme "retenue"
69
	 */
70
	private function modifierObservationParDetermination($id_proposition, $auteurId) {
71
		$champs_a_modifier = array('nom_sel', 'nom_sel_nn', 'nom_ret', 'nom_ret_nn', 'nom_referentiel');
72
 
73
		// obtenirInformationDetermination()
74
		// TODO: else { LIMIT 1 ? }
75
		$proposition = $this->bdd->recuperer(sprintf('SELECT ce_observation, id_commentaire, %s FROM del_commentaire WHERE id_commentaire = %d AND %s',
76
											  implode(',', $champs_a_modifier),
77
											  intval($id_proposition),
78
											  $auteurId ? 'ce_utilisateur = ' . $this->bdd->proteger($auteurId) : 1));
79
 
80
		if(! $proposition) {
1444 raphael 81
			throw new Exception("Cette proposition est invalide.", RestServeur::HTTP_CODE_ERREUR);
82
		}
83
 
1450 raphael 84
 
85
		$obsId = $proposition['ce_observation'];
1440 raphael 86
		// obtenirInformationsObservation()
1450 raphael 87
		$realAuteurId = $this->bdd->recuperer(sprintf('SELECT ce_utilisateur FROM del_observation WHERE id_observation = %d',
88
													 intval($obsId)));
89
		$realAuteurId = $realAuteurId['ce_utilisateur']; // XXX: PHP-5.3
90
 
91
		if(! $this->validationReqOriginMatchObsAuthor($realAuteurId)) {
1440 raphael 92
			throw new Exception("Seul l'utilisateur ayant saisi l'observation peut la valider : veuillez vous identifier.\n",
93
								RestServeur::HTTP_CODE_ERREUR);
94
		}
95
 
1450 raphael 96
		$parametres_formates = array_intersect_key($proposition,
97
												   array_flip($champs_a_modifier));
98
		$parametres_formates = array_merge($parametres_formates,
99
										   array('id_observation' => $obsId,
100
												 'ce_utilisateur' => $realAuteurId,
101
												 // on change la "certitude" de l'observation correspondante
102
												 'certitude' => 'Certaine',
103
												 'obsKeywordDelete' => 'adeterminer'));
104
		$ret = $this->conteneur->getRestClient()->modifier($this->conteneur->getParametre('url_service_validation_base') . $obsId,
105
														   $parametres_formates);
1444 raphael 106
		// cf cel/jrest/services/CelValidationObservation.php::updateElement()
107
		// TODO: check sur HTTP code == 200, plutôt que sur texte
108
		if($ret == 'ok' || $ret == 'OK') {
109
			// remet à 0 le status "proposition_retenue" pour toutes les propositions faites sur cette
110
			// observation à l'exception de celle désormais validée
111
			$this->bdd->requeter(sprintf('UPDATE del_commentaire SET proposition_retenue = IF(id_commentaire = %d, 1, 0)' .
112
										 ' WHERE ce_observation = %d -- %s',
1450 raphael 113
										 $proposition['id_commentaire'], $obsId, __FILE__ . ':' . __LINE__));
1444 raphael 114
		}
115
		return $ret;
1252 aurelien 116
	}
117
 
1450 raphael 118
	private function validationReqOriginMatchObsAuthor($ce_utilisateur) {
1252 aurelien 119
		$controle_utilisateur = new ControleAcces($this->conteneur);
120
		$utilisateur_connecte = $controle_utilisateur->getInfosUtilisateurConnecte();
1440 raphael 121
		return $ce_utilisateur == $utilisateur_connecte['id_utilisateur'];
1252 aurelien 122
	}
1450 raphael 123
}