Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1457 Rev 1601
Line 1... Line 1...
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	php 5.2
7
 * @category	php 5.2
8
 * @package	del
8
 * @package	del
9
 * @subpackage images
9
 * @subpackage images
Line 14... Line 14...
14
 * @version	$Id$
14
 * @version	$Id$
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
15
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Images
16
 */
16
 */
Line 17... Line 17...
17
 
17
 
18
class ValiderDetermination {
18
class ValiderDetermination {
19
	
19
 
20
	private $conteneur;
20
	private $conteneur;
21
	private $navigation;
21
	private $navigation;
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
	
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->conteneur->chargerConfiguration('config_determinations.ini');
30
		$this->conteneur->chargerConfiguration('config_determinations.ini');
31
		$this->gestionBdd = $conteneur->getGestionBdd();
31
		$this->gestionBdd = $conteneur->getGestionBdd();
32
		$this->bdd = $this->gestionBdd->getBdd();	
32
		$this->bdd = $this->gestionBdd->getBdd();
33
	}
33
	}
34
	
34
 
35
	public function modifier($ressources, $parametres) {
35
	public function modifier($ressources, $parametres) {
36
		$this->verifierParametres($ressources, $parametres);
36
		$this->verifierParametres($ressources, $parametres);
37
		$id_proposition = $ressources[1];
37
		$id_proposition = $ressources[1];
38
		
38
 
39
		$e = $this->modifierObservationParDetermination($id_proposition, $parametres['auteur.id']);
39
		$e = $this->modifierObservationParDetermination($id_proposition, $parametres['auteur.id']);
40
		if($e == 'ok' || $e == 'OK' || $e == 'Not Modified') {
40
		if($e == 'ok' || $e == 'OK' || $e == 'Not Modified') {
41
			RestServeur::envoyerEnteteStatutHttp(RestServeur::HTTP_CODE_OK);
41
			RestServeur::envoyerEnteteStatutHttp(RestServeur::HTTP_CODE_OK);
42
			return;
42
			return;
43
		}
43
		}
44
		throw new Exception("error: Cel returned \"$e\"", RestServeur::HTTP_CODE_ERREUR);
44
		throw new Exception("error: Cel returned \"$e\"", RestServeur::HTTP_CODE_ERREUR);
45
	}
45
	}
46
	
46
 
47
	public function verifierParametres($ressources, $parametres) {
47
	public function verifierParametres($ressources, $parametres) {
48
		$erreurs = array();
48
		$erreurs = array();
49
		if (!is_numeric($ressources[1])) {
49
		if (!is_numeric($ressources[1])) {
50
			$erreurs[] = '- le paramètre indiquant l\'identifiant de la proposition doit être numérique ;';
50
			$erreurs[] = '- le paramètre indiquant l\'identifiant de la proposition doit être numérique ;';
Line 53... Line 53...
53
		//Le paramètre auteur.id (id de l'auteur de la détermination)
53
		//Le paramètre auteur.id (id de l'auteur de la détermination)
54
		// est là pour éviter que le $_POST ne soit vide
54
		// est là pour éviter que le $_POST ne soit vide
55
		if (!isset($parametres['auteur.id'])) {
55
		if (!isset($parametres['auteur.id'])) {
56
			$erreurs[] = '- paramètre "auteur.id" manquant ;';
56
			$erreurs[] = '- paramètre "auteur.id" manquant ;';
57
		}
57
		}
58
		
58
 
59
		if ($erreurs) {
59
		if ($erreurs) {
60
			throw new Exception("Erreur lors de la configuration :\n" . implode("\n", $erreurs),
60
			throw new Exception("Erreur lors de la configuration :\n" . implode("\n", $erreurs),
61
								RestServeur::HTTP_CODE_ERREUR);
61
								RestServeur::HTTP_CODE_ERREUR);
62
		}
62
		}
63
	}
63
	}
64
	
64
 
65
	/*
65
	/*
66
	 * 1) récupère l'observation, autrement échec
66
	 * 1) récupère l'observation, autrement échec
67
	 * 2) récupère et l'auteur officiel et valide l'authentification (match sur $_POST['auteur.id'] et $_SESSION), autrement échec
67
	 * 2) récupère et l'auteur officiel et valide l'authentification (match sur $_POST['auteur.id'] et $_SESSION), autrement échec
68
	 * 3) prépare les nouvelles valeurs à mettre à jour dans cel_obs depuis del_commentaire
68
	 * 3) prépare les nouvelles valeurs à mettre à jour dans cel_obs depuis del_commentaire
69
	 * 4) effectue la mise à jour
69
	 * 4) effectue la mise à jour
Line 73... Line 73...
73
		$champs_a_modifier = array('nom_sel', 'nom_sel_nn', 'nom_ret', 'nom_ret_nn', 'nom_referentiel');
73
		$champs_a_modifier = array('nom_sel', 'nom_sel_nn', 'nom_ret', 'nom_ret_nn', 'nom_referentiel');
Line 74... Line 74...
74
 
74
 
75
		// obtenirInformationDetermination()
75
		// obtenirInformationDetermination()
76
		// TODO: else { LIMIT 1 ? }
76
		// TODO: else { LIMIT 1 ? }
77
		$proposition = $this->bdd->recuperer(sprintf('SELECT ce_observation, id_commentaire, %s FROM del_commentaire WHERE id_commentaire = %d AND %s',
77
		$proposition = $this->bdd->recuperer(sprintf('SELECT ce_observation, id_commentaire, %s FROM del_commentaire WHERE id_commentaire = %d AND %s',
78
											  implode(',', $champs_a_modifier), 
78
											  implode(',', $champs_a_modifier),
79
											  intval($id_proposition),
79
											  intval($id_proposition),
Line 80... Line 80...
80
											  $auteurId ? 'ce_utilisateur = ' . $this->bdd->proteger($auteurId) : 1));
80
											  $auteurId ? 'ce_utilisateur = ' . $this->bdd->proteger($auteurId) : 1));
81
 
81
 
Line 114... Line 114...
114
										 ' WHERE ce_observation = %d -- %s',
114
										 ' WHERE ce_observation = %d -- %s',
115
										 $proposition['id_commentaire'], $obsId, __FILE__ . ':' . __LINE__));
115
										 $proposition['id_commentaire'], $obsId, __FILE__ . ':' . __LINE__));
116
		}
116
		}
117
		return $ret;
117
		return $ret;
118
	}
118
	}
119
	
119
 
120
	private function validationReqOriginMatchObsAuthor($ce_utilisateur) {	
120
	private function validationReqOriginMatchObsAuthor($ce_utilisateur) {
121
		$controle_utilisateur = new ControleAcces($this->conteneur);
121
		$controle_utilisateur = $this->conteneur->getControleAcces();
122
		$utilisateur_connecte = $controle_utilisateur->getInfosUtilisateurConnecte();
122
		$utilisateur_connecte = $controle_utilisateur->getInfosUtilisateurConnecte();
123
		return $ce_utilisateur == $utilisateur_connecte['id_utilisateur'];
123
		return $ce_utilisateur == $utilisateur_connecte['id_utilisateur'];
124
	}
124
	}
125
}
125
}
126
126