Subversion Repositories eFlore/Applications.del

Rev

Rev 1978 | Rev 2117 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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