Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1362 Rev 1666
Line 13... Line 13...
13
 * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
13
 * @version	$Id: Bdd.php 403 2012-02-22 14:35:20Z gduche $
14
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Observations
14
 * @see http://www.tela-botanica.org/wikini/eflore/wakka.php?wiki=ApiIdentiplante01Observations
15
 */
15
 */
Line 16... Line 16...
16
 
16
 
17
class Preferences {
17
class Preferences {
18
	
18
 
19
	private $conteneur;
19
	private $conteneur;
20
	private $gestionBdd;
20
	private $gestionBdd;
21
	private $bdd;
21
	private $bdd;
22
	
22
 
23
	public function __construct(Conteneur $conteneur = null) {
23
	public function __construct(Conteneur $conteneur = null) {
24
		session_start();
24
		session_start();
25
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
25
		$this->conteneur = $conteneur == null ? new Conteneur() : $conteneur;
26
		$this->conteneur->chargerConfiguration('config_utilisateurs.ini');
26
		$this->conteneur->chargerConfiguration('config_utilisateurs.ini');
27
		$this->gestionBdd = $conteneur->getGestionBdd();
27
		$this->gestionBdd = $conteneur->getGestionBdd();
28
		$this->bdd = $this->gestionBdd->getBdd();
28
		$this->bdd = $this->gestionBdd->getBdd();
29
	}
29
	}
30
	
30
 
31
	/**
31
	/**
32
	 * Renvoie les préférences utilisateurs
32
	 * Renvoie les préférences utilisateurs
33
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
33
	 * @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
34
	 * @param array $parametres les paramètres situés après le ? dans l'url
34
	 * @param array $parametres les paramètres situés après le ? dans l'url
35
	 * */
35
	 * */
36
	public function consulter($ressources, $parametres) {
-
 
37
		
36
	public function consulter($ressources, $parametres) {
38
		$id_utilisateur = $ressources[0];
37
		$id_utilisateur = $ressources[0];
39
		$prefs = $this->obtenirPreferencesUtilisateur($id_utilisateur);
38
		$prefs = $this->obtenirPreferencesUtilisateur($id_utilisateur);
40
		// Mettre en forme le résultat et l'envoyer pour affichage
39
		// Mettre en forme le résultat et l'envoyer pour affichage
41
		$resultat = new ResultatService();
40
		$resultat = new ResultatService();
42
		$resultat->corps = $prefs;
41
		$resultat->corps = $prefs;
43
		return $resultat;
42
		return $resultat;
44
	}
43
	}
45
	
-
 
46
	/**
-
 
47
	* Méthode principale de la classe.
-
 
48
	* Modifie les préférences utilisateurs
-
 
49
	* @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
-
 
50
	* @param array $parametres les paramètres situés dans le post
-
 
51
	* */
-
 
52
	public function modifier($ressources, $parametres) {
-
 
53
		$id_utilisateur = $ressources[0];
-
 
54
		$prefs = $this->modifierPreferencesUtilisateur($id_utilisateur, $parametres);
-
 
55
		// Mettre en forme le résultat et l'envoyer pour affichage
-
 
56
		$resultat = new ResultatService();
-
 
57
		$resultat->corps = $prefs;
-
 
58
		return $resultat;
-
 
59
	}
-
 
60
	
44
 
61
	private function obtenirPreferencesUtilisateur($id_utilisateur) {
45
	private function obtenirPreferencesUtilisateur($id_utilisateur) {
62
		$requete = 'SELECT * FROM del_utilisateur_infos WHERE id_utilisateur = '.$this->bdd->proteger($id_utilisateur);
46
		$requete = 'SELECT * FROM del_utilisateur_infos WHERE id_utilisateur = '.$this->bdd->proteger($id_utilisateur);
63
		$prefs_utilisateur = $this->bdd->recupererTous($requete);
47
		$prefs_utilisateur = $this->bdd->recupererTous($requete);
64
		
48
 
65
		if(empty($prefs_utilisateur)) {
49
		if (empty($prefs_utilisateur)) {
66
			$this->initialiserInfosUtilisateur($id_utilisateur);
50
			$this->initialiserInfosUtilisateur($id_utilisateur);
67
			$prefs_utilisateur = $this->renvoyerInfosUtilisateurDefaut($id_utilisateur);
51
			$prefs_utilisateur = $this->renvoyerInfosUtilisateurDefaut($id_utilisateur);
68
		} else {
52
		} else {
69
			$prefs_utilisateur = $prefs_utilisateur[0];
53
			$prefs_utilisateur = $prefs_utilisateur[0];
70
			$prefs_utilisateur['preferences'] = json_decode($prefs_utilisateur['preferences']);
54
			$prefs_utilisateur['preferences'] = json_decode($prefs_utilisateur['preferences']);
71
			$prefs_utilisateur['admin'] = $prefs_utilisateur['admin'];
55
			$prefs_utilisateur['admin'] = $prefs_utilisateur['admin'];
72
		}
56
		}
73
		
57
 
74
		return $prefs_utilisateur;
58
		return $prefs_utilisateur;
75
	}
59
	}
76
	
-
 
77
	private function modifierPreferencesUtilisateur($id_utilisateur, $prefs) {
-
 
78
		$requete = 'UPDATE del_utilisateur_infos '.
-
 
79
					           'SET preferences = '.$this->bdd->proteger(json_encode($prefs)).' '.
-
 
80
							   'WHERE id_utilisateur = '.$this->bdd->proteger($id_utilisateur);
-
 
81
		
-
 
82
		$resultat = $this->bdd->requeter($requete);
-
 
83
		return $resultat;
-
 
84
	}
-
 
85
	
60
 
86
	private function initialiserInfosUtilisateur($id_utilisateur) {
-
 
87
		
61
	private function initialiserInfosUtilisateur($id_utilisateur) {
88
		$preferences_defaut = $this->obtenirTableauPreferenceDefaut();
-
 
-
 
62
		$preferences_defaut = $this->obtenirTableauPreferenceDefaut();
-
 
63
		$prefsEncodeesP = $this->bdd->proteger(json_encode($preferences_defaut));
89
		
64
		$idUtilisateurP = $this->bdd->proteger($id_utilisateur);
90
		$requete = 'INSERT INTO del_utilisateur_infos '.
65
		$requete = 'INSERT INTO del_utilisateur_infos '.
91
			           '(id_utilisateur, admin, preferences, date_premiere_utilisation )'.
-
 
92
			           'VALUES '.
66
				'(id_utilisateur, admin, preferences, date_premiere_utilisation )'.
93
			           "(".$this->bdd->proteger($id_utilisateur).", 0, ".$this->bdd->proteger(json_encode($preferences_defaut)).", NOW()) ".
67
				"VALUES ($idUtilisateurP, 0, $prefsEncodeesP, NOW()) ".
94
			           'ON DUPLICATE KEY UPDATE date_premiere_utilisation = NOW() ';
68
				'ON DUPLICATE KEY UPDATE date_premiere_utilisation = NOW() ';
95
	
69
 
96
		$resultat = $this->bdd->requeter($requete);
70
		$resultat = $this->bdd->requeter($requete);
97
		return $resultat;
71
		return $resultat;
98
	}
72
	}
-
 
73
 
-
 
74
	private function obtenirTableauPreferenceDefaut() {
-
 
75
		return array('mail_notification_mes_obs' => '1', 'mail_notification_toutes_obs' => '0');
-
 
76
	}
99
	
77
 
100
	private function renvoyerInfosUtilisateurDefaut($id_utilisateur) {
78
	private function renvoyerInfosUtilisateurDefaut($id_utilisateur) {
101
		return array('id_utilisateur' => $id_utilisateur, 
79
		return array('id_utilisateur' => $id_utilisateur,
102
					 'admin' => "0", 
80
				'admin' => '0',
103
					 'preferences' => $this->obtenirTableauPreferenceDefaut(),
81
				'preferences' => $this->obtenirTableauPreferenceDefaut(),
104
					  'date_premiere_utilisation' => date('Y-m-d H:i:s'));
82
				'date_premiere_utilisation' => date('Y-m-d H:i:s'));
105
	}
83
	}
-
 
84
 
-
 
85
	/**
-
 
86
	* Méthode principale de la classe.
-
 
87
	* Modifie les préférences utilisateurs
-
 
88
	* @param array $ressources les ressources situées après l'url de base (ex : http://url/ressource1/ressource2)
-
 
89
	* @param array $parametres les paramètres situés dans le post
106
	
90
	* */
-
 
91
	public function modifier($ressources, $parametres) {
-
 
92
		$id_utilisateur = $ressources[0];
-
 
93
		$prefs = $this->modifierPreferencesUtilisateur($id_utilisateur, $parametres);
-
 
94
		// Mettre en forme le résultat et l'envoyer pour affichage
-
 
95
		$resultat = new ResultatService();
-
 
96
		$resultat->corps = $prefs;
-
 
97
		return $resultat;
-
 
98
	}
-
 
99
 
107
	private function obtenirTableauPreferenceDefaut() {
100
	private function modifierPreferencesUtilisateur($id_utilisateur, $prefs) {
-
 
101
		$requete = 'UPDATE del_utilisateur_infos '.
-
 
102
			'SET preferences = '.$this->bdd->proteger(json_encode($prefs)).' '.
-
 
103
			'WHERE id_utilisateur = '.$this->bdd->proteger($id_utilisateur);
108
		return array('mail_notification_mes_obs' => "1",
104
 
-
 
105
		$resultat = $this->bdd->requeter($requete);
109
					 'mail_notification_toutes_obs' => "0");
106
		return $resultat;
110
	}
107
	}
111
}
108
}
112
?>
109
?>