| 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 |   | 
        
           | 2117 | mathias | 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;
 | 
        
           | 1931 | aurelien | 138 | 	}
 | 
        
           | 1450 | raphael | 139 |   | 
        
           | 1684 | jpm | 140 | 	private function verifierDroitUtilisateur() {
 | 
        
           | 2077 | mathias | 141 | 		$gestionUtilisateur = $this->conteneur->getUtilisateur();
 | 
        
           |  |  | 142 | 		$utilisateurInfos = $gestionUtilisateur->getUtilisateur();
 | 
        
           | 1684 | jpm | 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é
 | 
        
           | 2117 | mathias | 169 | 		$gestionUtilisateur = $this->conteneur->getUtilisateur();
 | 
        
           | 2077 | mathias | 170 | 		$utilisateurInfos = $gestionUtilisateur->getUtilisateur();
 | 
        
           | 1931 | aurelien | 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'],
 | 
        
           | 2117 | mathias | 177 | 					'lien_profil'	=> sprintf($this->conteneur->getParametre('message.lien_profil'), $this->idValidateurObs),
 | 
        
           | 1931 | aurelien | 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 |   | 
        
           | 2117 | mathias | 185 | 		$squelettePhp = $this->conteneur->getSquelettePhp();
 | 
        
           |  |  | 186 | 		$squeletteHtml = dirname(__FILE__).DS.'squelettes'.DS.'validation_determination.tpl.html';
 | 
        
           | 1931 | aurelien | 187 | 		$corpsHtml = $squelettePhp->analyser($squeletteHtml, $donnees);
 | 
        
           |  |  | 188 |   | 
        
           | 2117 | mathias | 189 | 		$squeletteTxt = dirname(__FILE__).DS.'squelettes'.DS.'validation_determination.tpl.txt';
 | 
        
           | 1931 | aurelien | 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 | }
 |