Subversion Repositories Applications.annuaire

Rev

Rev 356 | Rev 416 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
49 aurelien 1
<?php
2
/**
3
* PHP Version 5
4
*
5
* @category  PHP
6
* @package   annuaire
7
* @author    aurelien <aurelien@tela-botanica.org>
8
* @copyright 2010 Tela-Botanica
9
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @version   SVN: <svn_id>
11
* @link      /doc/annuaire/
12
*/
13
 
14
Class DonneeTemporaireModele extends Modele {
15
 
16
	private $config = array();
199 aurelien 17
 
80 aurelien 18
	public function stockerDonneeTemporaire($donnee, $id_aleatoire = false) {
199 aurelien 19
 
49 aurelien 20
		// on protège et on sérialise les données
80 aurelien 21
		$identifiant = $this->calculerIdentifiant($id_aleatoire);
49 aurelien 22
		$donnees = $this->encoderDonneeTemporaire($donnee);
23
 
351 aurelien 24
		$requete_insertion = 'INSERT INTO annu_donnees_temp ('.
25
					      'adt_id ,'.
26
					      'adt_donnees ,'.
27
					      'adt_date'.
28
					      ')'.
49 aurelien 29
					'VALUES '.
30
					'('.$this->proteger($identifiant).','.$this->proteger($donnees).', NOW())';
31
 
313 aurelien 32
		$insertion = $this->requete($requete_insertion);
49 aurelien 33
 
313 aurelien 34
		if(!$insertion) {
35
			return false;
36
		}
37
 
49 aurelien 38
		return $identifiant;
39
 
40
	}
351 aurelien 41
 
42
	public function chargerListeDonneeTemporaire($longueur_id = '8') {
43
 
44
		$requete_chargement_donnee = 'SELECT * FROM annu_donnees_temp '.
45
									' WHERE LENGTH(adt_id) = '.$longueur_id.
46
									' ORDER BY adt_date DESC';
49 aurelien 47
 
351 aurelien 48
		$donnees_temp = $this->requeteTous($requete_chargement_donnee);
49
 
50
		foreach ($donnees_temp as &$donnee) {
51
 
52
			$code_confirmation = $donnee['adt_id'];
53
			$date_donnee_temp = $donnee['adt_date'];
54
			$donnee = $this->decoderDonneeTemporaire($donnee);
55
 
56
			$donnee['code_confirmation'] = $code_confirmation;
57
			$donnee['date'] = $date_donnee_temp;
58
		}
59
 
60
		return $donnees_temp;
61
	}
62
 
49 aurelien 63
	public function chargerDonneeTemporaire($code_donnee) {
199 aurelien 64
 
49 aurelien 65
		$requete_chargement_donnee = 'SELECT * FROM annu_donnees_temp '.
66
									' WHERE adt_id = '.$this->proteger($code_donnee);
67
 
68
		$donnees_temp = $this->requeteUn($requete_chargement_donnee);
69
 
70
		if($donnees_temp) {
71
			return $this->decoderDonneeTemporaire($donnees_temp);
72
		} else {
73
			return false;
74
		}
75
	}
76
 
77
	public function supprimerDonneeTemporaire($code_donnee) {
78
 
79
		$requete_suppression_donnee = 'DELETE FROM annu_donnees_temp '.
80
									' WHERE adt_id = '.$this->proteger($code_donnee);
81
 
356 aurelien 82
		$resultat_suppression = $this->requete($requete_suppression_donnee);
49 aurelien 83
 
84
		if($resultat_suppression) {
85
			return true;
86
		} else {
87
			return false;
88
		}
89
	}
90
 
91
	private function decoderDonneeTemporaire($donnee_encodee) {
92
 
93
		return unserialize(base64_decode($donnee_encodee['adt_donnees']));
94
	}
95
 
96
	private function encoderDonneeTemporaire($donnee) {
97
 
98
		return base64_encode(serialize($donnee));
99
	}
100
 
80 aurelien 101
	private function calculerIdentifiant($aleatoire = false) {
49 aurelien 102
 
80 aurelien 103
		if(!$aleatoire) {
104
			// Le code de confirmation est constitué des 8 premiers caractères de l'identifiant de session
123 aurelien 105
			// lors du stockage des données d'inscription, afin d'éviter d'accumuler les demandes
106
			// d'inscription pour une même session
80 aurelien 107
			$code_confirmation = substr(session_id(), 0, 8) ;
108
		} else {
415 raphael 109
			// Ce code est à l'intention de la modération pour valider un email en attente de modération
110
			// mais qui doit être unique pour éviter des duplicates keys.
111
			$code_confirmation = time();
80 aurelien 112
		}
49 aurelien 113
 
114
		return $code_confirmation;
115
	}
199 aurelien 116
 
117
	private function maintenanceDonneesTemporaires() {
118
 
119
		$requete_suppression_vieilles_donnees = 'DELETE FROM annu_donnees_temp';
120
												' WHERE adt_date < (DATE_SUB(now(), INTERVAL 14 DAY))';
121
 
122
		$resultat_suppression_vieilles_donnees = $this->requeteUn($requete_suppression_vieilles_donnees);
123
 
124
		if($resultat_suppression_vieilles_donnees) {
125
			return true;
126
		} else {
127
			return false;
128
		}
129
	}
49 aurelien 130
 
131
}
313 aurelien 132
?>