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) {
|
1978 |
aurelien |
40 |
$msg = "Erreur: le web service du CEL a retourné : $retourCel";
|
1700 |
jpm |
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();
|
1931 |
aurelien |
100 |
if($this->idAuteurObs != $this->idValidateurObs) {
|
|
|
101 |
$this->avertirAuteurObservation();
|
|
|
102 |
}
|
1684 |
jpm |
103 |
}
|
|
|
104 |
return $retour;
|
|
|
105 |
}
|
|
|
106 |
|
|
|
107 |
private function getInfosProposition() {
|
|
|
108 |
$idPropositionP = $this->bdd->proteger($this->idProposition);
|
|
|
109 |
$requete = "SELECT id_commentaire, ce_observation, nom_sel_nn, nom_referentiel ".
|
|
|
110 |
'FROM del_commentaire '.
|
|
|
111 |
"WHERE id_commentaire = $idPropositionP ".
|
|
|
112 |
' -- '.__FILE__.' : '.__LINE__;
|
|
|
113 |
$resultat = $this->bdd->recuperer($requete);
|
|
|
114 |
if (! $resultat) {
|
1444 |
raphael |
115 |
throw new Exception("Cette proposition est invalide.", RestServeur::HTTP_CODE_ERREUR);
|
|
|
116 |
}
|
1684 |
jpm |
117 |
return $resultat;
|
|
|
118 |
}
|
1444 |
raphael |
119 |
|
1684 |
jpm |
120 |
private function getIdAuteurObs() {
|
|
|
121 |
$obsIdP = $this->bdd->proteger($this->idObs);
|
|
|
122 |
$requete = 'SELECT ce_utilisateur '.
|
|
|
123 |
'FROM del_observation '.
|
|
|
124 |
"WHERE id_observation = $obsIdP ".
|
|
|
125 |
' -- '.__FILE__.' : '.__LINE__;
|
|
|
126 |
$auteurInfo = $this->bdd->recuperer($requete);
|
|
|
127 |
return $auteurInfo['ce_utilisateur'];
|
|
|
128 |
}
|
1931 |
aurelien |
129 |
|
|
|
130 |
private function getInfosObs() {
|
|
|
131 |
$obsIdP = $this->bdd->proteger($this->idObs);
|
|
|
132 |
$requete = 'SELECT * '.
|
|
|
133 |
'FROM del_observation '.
|
|
|
134 |
"WHERE id_observation = $obsIdP ".
|
|
|
135 |
' -- '.__FILE__.' : '.__LINE__;
|
|
|
136 |
$obsInfos = $this->bdd->recuperer($requete);
|
|
|
137 |
return $obsInfos;
|
|
|
138 |
}
|
1450 |
raphael |
139 |
|
1684 |
jpm |
140 |
private function verifierDroitUtilisateur() {
|
|
|
141 |
$controleAcces = $this->conteneur->getControleAcces();
|
|
|
142 |
$utilisateurInfos = $controleAcces->getInfosUtilisateurConnecte();
|
|
|
143 |
$utilisateurId = $utilisateurInfos['id_utilisateur'];
|
1793 |
jpm |
144 |
|
1773 |
aurelien |
145 |
// si l'utilisateur connecté n'est ni auteur de l'observation, ni au moins administrateur de niveau 1
|
|
|
146 |
if (($this->idAuteurObs != $utilisateurId) && $utilisateurInfos['admin'] < 1) {
|
|
|
147 |
$msg = "Seul l'utilisateur ayant saisi l'observation, un administrateur ou un validateur peut la valider : veuillez vous identifier.\n";
|
1684 |
jpm |
148 |
throw new Exception($msg, RestServeur::HTTP_CODE_ERREUR);
|
1440 |
raphael |
149 |
}
|
1252 |
aurelien |
150 |
}
|
1601 |
jpm |
151 |
|
1684 |
jpm |
152 |
/**
|
|
|
153 |
* Remet à 0 le status "proposition_retenue" pour toutes les propositions faites sur cette
|
1773 |
aurelien |
154 |
* observation à l'exception de celle désormais validée (qui voit son ce_validateur et sa date validation mise à jour)
|
1684 |
jpm |
155 |
*/
|
|
|
156 |
private function mettreAJourPropositionRetenue() {
|
|
|
157 |
$requete = 'UPDATE del_commentaire '.
|
1773 |
aurelien |
158 |
"SET proposition_retenue = IF(id_commentaire = {$this->idProposition}, 1, 0), ".
|
|
|
159 |
"ce_validateur = IF(id_commentaire = {$this->idProposition}, {$this->idValidateurObs} , ce_validateur), ".
|
|
|
160 |
"date_validation = IF(id_commentaire = {$this->idProposition}, NOW() , date_validation) ".
|
1684 |
jpm |
161 |
"WHERE ce_observation = {$this->idObs} ".
|
|
|
162 |
' -- '.__FILE__.' : '.__LINE__;
|
1773 |
aurelien |
163 |
|
1684 |
jpm |
164 |
return $this->bdd->requeter($requete);
|
1252 |
aurelien |
165 |
}
|
1931 |
aurelien |
166 |
|
|
|
167 |
private function avertirAuteurObservation() {
|
|
|
168 |
// le validateur est forcément celui qui est actuellement connecté
|
|
|
169 |
$controleAcces = $this->conteneur->getControleAcces();
|
|
|
170 |
$utilisateurInfos = $controleAcces->getInfosUtilisateurConnecte();
|
|
|
171 |
|
|
|
172 |
$infos_obs = $this->getInfosObs();
|
|
|
173 |
|
|
|
174 |
$donnees = array(
|
|
|
175 |
'auteur_obs_fmt' => $infos_obs['prenom_utilisateur'].' '.$infos_obs['nom_utilisateur'],
|
|
|
176 |
'validateur_fmt' => $utilisateurInfos['prenom']." ".$utilisateurInfos['nom'],
|
|
|
177 |
'lien_profil' => sprintf($this->conteneur->getParametre('message.lien_profil'), $this->idObs),
|
|
|
178 |
'id_obs' => $this->idObs,
|
|
|
179 |
'lien_obs' => sprintf($this->conteneur->getParametre('obs_fiche_tpl'), $this->idObs),
|
|
|
180 |
'lien_wiki' => $this->conteneur->getParametre('message.lien_wiki_validation')
|
|
|
181 |
);
|
|
|
182 |
|
|
|
183 |
$sujet = $this->conteneur->getParametre('message.titre_message_validation');
|
|
|
184 |
|
|
|
185 |
$squelettePhp = $this->conteneur->getSquelettePhp();
|
|
|
186 |
$squeletteHtml = dirname(__FILE__).DS.'squelettes'.DS.'validation_determination.tpl.html';
|
|
|
187 |
$corpsHtml = $squelettePhp->analyser($squeletteHtml, $donnees);
|
|
|
188 |
|
|
|
189 |
$squeletteTxt = dirname(__FILE__).DS.'squelettes'.DS.'validation_determination.tpl.txt';
|
|
|
190 |
$corpsTxt = $squelettePhp->analyser($squeletteTxt, $donnees);
|
|
|
191 |
|
|
|
192 |
$messagerie = $this->conteneur->getMessagerie();
|
1935 |
aurelien |
193 |
$messagerie->envoyerHtml($infos_obs['courriel_utilisateur'],
|
1931 |
aurelien |
194 |
$sujet,
|
|
|
195 |
$corpsHtml,
|
|
|
196 |
$corpsTxt);
|
|
|
197 |
}
|
1450 |
raphael |
198 |
}
|