Subversion Repositories eFlore/Applications.del

Rev

Rev 1601 | Rev 1700 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1601 Rev 1684
Line 22... Line 22...
22
	private $masque;
22
	private $masque;
23
	private $gestionBdd;
23
	private $gestionBdd;
24
	private $bdd;
24
	private $bdd;
25
	private $parametres = array();
25
	private $parametres = array();
26
	private $ressources = array();
26
	private $ressources = array();
-
 
27
	private $idObs = null;
-
 
28
	private $idProposition = null;
-
 
29
	private $idAuteurObs = null;
Line 27... Line 30...
27
 
30
 
28
	public function __construct(Conteneur $conteneur = null) {
31
	public function __construct(Conteneur $conteneur = null) {
29
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
32
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
30
		$this->conteneur->chargerConfiguration('config_determinations.ini');
33
		$this->conteneur->chargerConfiguration('config_determinations.ini');
31
		$this->gestionBdd = $conteneur->getGestionBdd();
34
		$this->gestionBdd = $conteneur->getGestionBdd();
32
		$this->bdd = $this->gestionBdd->getBdd();
35
		$this->bdd = $this->gestionBdd->getBdd();
Line 33... Line 36...
33
	}
36
	}
34
 
37
 
35
	public function modifier($ressources, $parametres) {
38
	public function modifier($ressources, $parametres) {
-
 
39
		$this->verifierParametres($ressources, $parametres);
Line 36... Line -...
36
		$this->verifierParametres($ressources, $parametres);
-
 
37
		$id_proposition = $ressources[1];
40
		$this->idProposition = $ressources[1];
38
 
41
		$e = $this->modifierObservationParDetermination();
39
		$e = $this->modifierObservationParDetermination($id_proposition, $parametres['auteur.id']);
42
 
-
 
43
		if ($e == 'ok' || $e == 'OK' || $e == 'Not Modified') {
40
		if($e == 'ok' || $e == 'OK' || $e == 'Not Modified') {
44
			RestServeur::envoyerEnteteStatutHttp(RestServeur::HTTP_CODE_OK);
41
			RestServeur::envoyerEnteteStatutHttp(RestServeur::HTTP_CODE_OK);
-
 
42
			return;
45
		} else {
Line 43... Line 46...
43
		}
46
			throw new Exception("Erreur: le web service du CEL a retourné : $e", RestServeur::HTTP_CODE_ERREUR);
44
		throw new Exception("error: Cel returned \"$e\"", RestServeur::HTTP_CODE_ERREUR);
47
		}
45
	}
48
	}
46
 
49
 
47
	public function verifierParametres($ressources, $parametres) {
50
	private function verifierParametres($ressources, $parametres) {
Line 48... Line 51...
48
		$erreurs = array();
51
		$erreurs = array();
49
		if (!is_numeric($ressources[1])) {
52
		if (!is_numeric($ressources[1])) {
50
			$erreurs[] = '- le paramètre indiquant l\'identifiant de la proposition doit être numérique ;';
53
			$erreurs[] = '- la ressource indiquant l\'identifiant de la proposition doit être numérique';
51
		}
54
		}
52
 
55
 
Line 53... Line 56...
53
		//Le paramètre auteur.id (id de l'auteur de la détermination)
56
		//Le paramètre auteur.id (id de l'auteur de la détermination)
54
		// est là pour éviter que le $_POST ne soit vide
57
		// est là pour éviter que le $_POST ne soit vide
55
		if (!isset($parametres['auteur.id'])) {
58
		if (!isset($parametres['auteur.id'])) {
56
			$erreurs[] = '- paramètre "auteur.id" manquant ;';
59
			$erreurs[] = "- le paramètre 'auteur.id' est manquant";
57
		}
60
		}
Line 58... Line 61...
58
 
61
 
59
		if ($erreurs) {
62
		if ($erreurs) {
60
			throw new Exception("Erreur lors de la configuration :\n" . implode("\n", $erreurs),
63
			$msg = "Erreur dans les paramètres d'appel au web service :\n" . implode("\n", $erreurs);
61
								RestServeur::HTTP_CODE_ERREUR);
64
			throw new Exception($msg, RestServeur::HTTP_CODE_ERREUR);
62
		}
65
		}
63
	}
66
	}
64
 
67
 
65
	/*
68
	/**
-
 
69
	 * 1) récupère l'observation, autrement échec
-
 
70
	 * 2) récupère et l'id auteur de l'obs et vérfie qu'il correspond à l'id de l'utilisateur actuel
-
 
71
	 * 3) prépare les nouvelles valeurs à transférer au service CEL
-
 
72
	 * 4) effectue la mise à jour
-
 
73
	 * 5) si tout s'est passé comme convenu, marque la proposition comme "retenue"
-
 
74
	 */
-
 
75
	private function modifierObservationParDetermination() {
-
 
76
		$propositionInfos = $this->getInfosProposition();
66
	 * 1) récupère l'observation, autrement échec
77
		$this->idObs = $propositionInfos['ce_observation'];
-
 
78
		$this->idAuteurObs = $this->getIdAuteurObs();
-
 
79
		$this->verifierDroitUtilisateur();
-
 
80
 
-
 
81
		$parametres = array(
-
 
82
			'id_observation' => $this->idObs,
Line 67... Line 83...
67
	 * 2) récupère et l'auteur officiel et valide l'authentification (match sur $_POST['auteur.id'] et $_SESSION), autrement échec
83
			'nom_sel_nn' => $propositionInfos['nom_sel_nn'],
68
	 * 3) prépare les nouvelles valeurs à mettre à jour dans cel_obs depuis del_commentaire
84
			'nom_referentiel' => $propositionInfos['nom_referentiel'],
69
	 * 4) effectue la mise à jour
-
 
70
	 * 5) si tout s'est passé comme convenu, marque la proposition comme "retenue"
85
			'id_utilisateur' => $this->idAuteurObs);
-
 
86
 
71
	 */
87
		$urlBase = $this->conteneur->getParametre('urlServiceCelObs');
72
	private function modifierObservationParDetermination($id_proposition, $auteurId) {
-
 
-
 
88
		$url = $urlBase.$this->idObs;
Line -... Line 89...
-
 
89
		$retour = $this->conteneur->getRestClient()->modifier($url, $parametres);
-
 
90
 
-
 
91
		// TODO: check sur HTTP code == 200, plutôt que sur texte
-
 
92
		if ($retour == 'ok' || $retour == 'OK') {
-
 
93
			$this->mettreAJourPropositionRetenue();
-
 
94
		}
-
 
95
		return $retour;
73
		$champs_a_modifier = array('nom_sel', 'nom_sel_nn', 'nom_ret', 'nom_ret_nn', 'nom_referentiel');
96
	}
74
 
97
 
75
		// obtenirInformationDetermination()
98
	private function getInfosProposition() {
-
 
99
		$idPropositionP = $this->bdd->proteger($this->idProposition);
-
 
100
		$requete = "SELECT id_commentaire, ce_observation, nom_sel_nn, nom_referentiel ".
Line -... Line 101...
-
 
101
			'FROM del_commentaire '.
-
 
102
			"WHERE id_commentaire = $idPropositionP ".
-
 
103
			' -- '.__FILE__.' : '.__LINE__;
-
 
104
		$resultat = $this->bdd->recuperer($requete);
-
 
105
		if (! $resultat) {
-
 
106
			throw new Exception("Cette proposition est invalide.", RestServeur::HTTP_CODE_ERREUR);
-
 
107
		}
-
 
108
		return $resultat;
-
 
109
	}
Line 76... Line 110...
76
		// TODO: else { LIMIT 1 ? }
110
 
77
		$proposition = $this->bdd->recuperer(sprintf('SELECT ce_observation, id_commentaire, %s FROM del_commentaire WHERE id_commentaire = %d AND %s',
111
	private function getIdAuteurObs() {
78
											  implode(',', $champs_a_modifier),
112
		$obsIdP = $this->bdd->proteger($this->idObs);
79
											  intval($id_proposition),
-
 
80
											  $auteurId ? 'ce_utilisateur = ' . $this->bdd->proteger($auteurId) : 1));
113
		$requete = 'SELECT ce_utilisateur '.
81
 
114
			'FROM del_observation '.
82
		if(! $proposition) {
115
			"WHERE id_observation = $obsIdP ".
83
			throw new Exception("Cette proposition est invalide.", RestServeur::HTTP_CODE_ERREUR);
116
			' -- '.__FILE__.' : '.__LINE__;
84
		}
117
		$auteurInfo = $this->bdd->recuperer($requete);
85
 
118
		return $auteurInfo['ce_utilisateur'];
86
 
-
 
87
		$obsId = $proposition['ce_observation'];
-
 
88
		// obtenirInformationsObservation()
-
 
89
		$realAuteurId = $this->bdd->recuperer(sprintf('SELECT ce_utilisateur FROM del_observation WHERE id_observation = %d',
-
 
90
													 intval($obsId)));
-
 
91
		$realAuteurId = $realAuteurId['ce_utilisateur']; // XXX: PHP-5.3
-
 
92
 
-
 
93
		if(! $this->validationReqOriginMatchObsAuthor($realAuteurId)) {
-
 
94
			throw new Exception("Seul l'utilisateur ayant saisi l'observation peut la valider : veuillez vous identifier.\n",
-
 
95
								RestServeur::HTTP_CODE_ERREUR);
-
 
96
		}
-
 
97
 
-
 
98
		$parametres_formates = array_intersect_key($proposition,
-
 
99
												   array_flip($champs_a_modifier));
-
 
100
		$parametres_formates = array_merge($parametres_formates,
-
 
101
										   array('id_observation' => $obsId,
-
 
102
												 'ce_utilisateur' => $realAuteurId,
-
 
103
												 // on change la "certitude" de l'observation correspondante
-
 
104
												 'certitude' => 'Certaine',
-
 
105
												 'obsKeywordDelete' => 'adeterminer'));
-
 
106
		$ret = $this->conteneur->getRestClient()->modifier($this->conteneur->getParametre('url_service_validation_base') . $obsId,
-
 
107
														   $parametres_formates);
119
	}
Line -... Line 120...
-
 
120
 
-
 
121
	private function verifierDroitUtilisateur() {
-
 
122
		$controleAcces = $this->conteneur->getControleAcces();
-
 
123
		$utilisateurInfos = $controleAcces->getInfosUtilisateurConnecte();
108
		// cf cel/jrest/services/CelValidationObservation.php::updateElement()
124
		$utilisateurId = $utilisateurInfos['id_utilisateur'];
109
		// TODO: check sur HTTP code == 200, plutôt que sur texte
125
 
110
		if($ret == 'ok' || $ret == 'OK') {
126
		if ($this->idAuteurObs != $utilisateurId) {
-
 
127
			$msg = "Seul l'utilisateur ayant saisi l'observation peut la valider : veuillez vous identifier.\n";
-
 
128
			throw new Exception($msg, RestServeur::HTTP_CODE_ERREUR);
111
			// remet à 0 le status "proposition_retenue" pour toutes les propositions faites sur cette
129
		}
112
			// observation à l'exception de celle désormais validée
130
	}
113
			$this->bdd->requeter(sprintf('UPDATE del_commentaire SET proposition_retenue = IF(id_commentaire = %d, 1, 0)' .
131
 
114
										 ' WHERE ce_observation = %d -- %s',
132
	/**