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
/**
1601 jpm 4
 * Le web service récupére un identifiant de proposition et appelle un service web externe
1813 jpm 5
 * (du CEL) afin de modifier le nom de l'observation associée par celui de la proposition.
1252 aurelien 6
 *
1813 jpm 7
 * @category   DEL
8
 * @package    Services
9
 * @subpackage Determinations
10
 * @version    0.1
11
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
12
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
13
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
14
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
1252 aurelien 17
 */
18
 
19
class ValiderDetermination {
1601 jpm 20
 
1252 aurelien 21
	private $conteneur;
22
	private $bdd;
1684 jpm 23
	private $idObs = null;
24
	private $idProposition = null;
25
	private $idAuteurObs = null;
1773 aurelien 26
	private $idValidateurObs = null;
1601 jpm 27
 
1252 aurelien 28
	public function __construct(Conteneur $conteneur = null) {
29
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
1793 jpm 30
		$this->bdd = $this->conteneur->getBdd();
1252 aurelien 31
	}
1601 jpm 32
 
1252 aurelien 33
	public function modifier($ressources, $parametres) {
34
		$this->verifierParametres($ressources, $parametres);
1684 jpm 35
		$this->idProposition = $ressources[1];
1773 aurelien 36
		$this->idValidateurObs = $this->validateurEstPresent($parametres) ? $parametres['validateur.id'] : $parametres['auteur.id'] ;
1700 jpm 37
		$retourCel = $this->modifierObservationParDetermination();
1601 jpm 38
 
1700 jpm 39
		if (preg_match('/^(OK|Not Modified)$/i', $retourCel) == false) {
40
			$msg = "Erreur: le web service du CEL a retourné : $e";
41
			$code = RestServeur::HTTP_CODE_ERREUR;
42
			throw new Exception($msg, $code);
1456 raphael 43
		}
1700 jpm 44
		return 'OK';
1252 aurelien 45
	}
1793 jpm 46
 
1773 aurelien 47
	private function validateurEstPresent($parametres) {
48
		return isset($parametres['validateur.id']) && is_numeric($parametres['validateur.id']) && $parametres['validateur.id'] != 0;
49
	}
1601 jpm 50
 
1684 jpm 51
	private function verifierParametres($ressources, $parametres) {
1252 aurelien 52
		$erreurs = array();
53
		if (!is_numeric($ressources[1])) {
1813 jpm 54
			$erreurs[] = "La ressource indiquant l'identifiant de la proposition doit être numérique.";
1252 aurelien 55
		}
56
 
1773 aurelien 57
		// Le paramètre auteur.id (id de l'auteur de la détermination)
1252 aurelien 58
		// est là pour éviter que le $_POST ne soit vide
59
		if (!isset($parametres['auteur.id'])) {
1813 jpm 60
			$erreurs[] = "Le paramètre 'auteur.id' est manquant.";
1252 aurelien 61
		}
1793 jpm 62
		// Le paramètre validateur.id (id de la personne validant la détemrinatiuon)
63
		// est là pour éviter que le $_POST ne soit vide
64
		if (isset($parametres['validateur.id']) && !is_numeric($parametres['validateur.id'])) {
1813 jpm 65
			$erreurs[] = "Le paramètre 'validateur.id' doit être un entier.";
1773 aurelien 66
		}
1601 jpm 67
 
1440 raphael 68
		if ($erreurs) {
1813 jpm 69
			$msg = "Erreur dans les paramètres d'appel au web service :\n\n" . implode("\n", $erreurs);
1684 jpm 70
			throw new Exception($msg, RestServeur::HTTP_CODE_ERREUR);
1252 aurelien 71
		}
72
	}
1601 jpm 73
 
1684 jpm 74
	/**
1450 raphael 75
	 * 1) récupère l'observation, autrement échec
1813 jpm 76
	 * 2) récupère et l'id auteur de l'obs et vérifie qu'il correspond à l'id de l'utilisateur actuel
1684 jpm 77
	 * 3) prépare les nouvelles valeurs à transférer au service CEL
1450 raphael 78
	 * 4) effectue la mise à jour
79
	 * 5) si tout s'est passé comme convenu, marque la proposition comme "retenue"
80
	 */
1684 jpm 81
	private function modifierObservationParDetermination() {
82
		$propositionInfos = $this->getInfosProposition();
83
		$this->idObs = $propositionInfos['ce_observation'];
84
		$this->idAuteurObs = $this->getIdAuteurObs();
85
		$this->verifierDroitUtilisateur();
1450 raphael 86
 
1684 jpm 87
		$parametres = array(
1773 aurelien 88
				'id_observation' => $this->idObs,
89
				'nom_sel_nn' => $propositionInfos['nom_sel_nn'],
90
				'nom_referentiel' => $propositionInfos['nom_referentiel']
91
			);
1450 raphael 92
 
1684 jpm 93
		$urlBase = $this->conteneur->getParametre('urlServiceCelObs');
94
		$url = $urlBase.$this->idObs;
95
		$retour = $this->conteneur->getRestClient()->modifier($url, $parametres);
96
 
97
		// TODO: check sur HTTP code == 200, plutôt que sur texte
98
		if ($retour == 'ok' || $retour == 'OK') {
99
			$this->mettreAJourPropositionRetenue();
100
		}
101
		return $retour;
102
	}
103
 
104
	private function getInfosProposition() {
105
		$idPropositionP = $this->bdd->proteger($this->idProposition);
106
		$requete = "SELECT id_commentaire, ce_observation, nom_sel_nn, nom_referentiel ".
107
			'FROM del_commentaire '.
108
			"WHERE id_commentaire = $idPropositionP ".
109
			' -- '.__FILE__.' : '.__LINE__;
110
		$resultat = $this->bdd->recuperer($requete);
111
		if (! $resultat) {
1444 raphael 112
			throw new Exception("Cette proposition est invalide.", RestServeur::HTTP_CODE_ERREUR);
113
		}
1684 jpm 114
		return $resultat;
115
	}
1444 raphael 116
 
1684 jpm 117
	private function getIdAuteurObs() {
118
		$obsIdP = $this->bdd->proteger($this->idObs);
119
		$requete = 'SELECT ce_utilisateur '.
120
			'FROM del_observation '.
121
			"WHERE id_observation = $obsIdP ".
122
			' -- '.__FILE__.' : '.__LINE__;
123
		$auteurInfo = $this->bdd->recuperer($requete);
124
		return $auteurInfo['ce_utilisateur'];
125
	}
1450 raphael 126
 
1684 jpm 127
	private function verifierDroitUtilisateur() {
128
		$controleAcces = $this->conteneur->getControleAcces();
129
		$utilisateurInfos = $controleAcces->getInfosUtilisateurConnecte();
130
		$utilisateurId = $utilisateurInfos['id_utilisateur'];
1793 jpm 131
 
1773 aurelien 132
		// si l'utilisateur connecté n'est ni auteur de l'observation, ni au moins administrateur de niveau 1
133
		if (($this->idAuteurObs != $utilisateurId) && $utilisateurInfos['admin'] < 1) {
134
			$msg = "Seul l'utilisateur ayant saisi l'observation, un administrateur ou un validateur peut la valider : veuillez vous identifier.\n";
1684 jpm 135
			throw new Exception($msg, RestServeur::HTTP_CODE_ERREUR);
1440 raphael 136
		}
1252 aurelien 137
	}
1601 jpm 138
 
1684 jpm 139
	/**
140
	 * Remet à 0 le status "proposition_retenue" pour toutes les propositions faites sur cette
1773 aurelien 141
	 * observation à l'exception de celle désormais validée (qui voit son ce_validateur et sa date validation mise à jour)
1684 jpm 142
	 */
143
	private function mettreAJourPropositionRetenue() {
144
		$requete = 'UPDATE del_commentaire '.
1773 aurelien 145
			"SET proposition_retenue = IF(id_commentaire = {$this->idProposition}, 1, 0), ".
146
			"ce_validateur = IF(id_commentaire = {$this->idProposition}, {$this->idValidateurObs} , ce_validateur), ".
147
			"date_validation = IF(id_commentaire = {$this->idProposition}, NOW() , date_validation) ".
1684 jpm 148
			"WHERE ce_observation = {$this->idObs} ".
149
			' -- '.__FILE__.' : '.__LINE__;
1773 aurelien 150
 
1684 jpm 151
		return $this->bdd->requeter($requete);
1252 aurelien 152
	}
1450 raphael 153
}