Subversion Repositories Applications.annuaire

Rev

Rev 581 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 581 Rev 583
1
<?php
1
<?php
2
 
2
 
3
/**
3
/**
4
 * Permet au service Auth de connecter l'utilisateur auprès d'un partenaire,
4
 * Permet au service Auth de connecter l'utilisateur auprès d'un partenaire,
5
 * et de synchroniser un compte local
5
 * et de synchroniser un compte local
6
 * @author mathias
6
 * @author mathias
7
 */
7
 */
8
abstract class AuthPartner {
8
abstract class AuthPartner {
9
 
9
 
10
	/** Injection de dépendance du service Auth, pour utiliser les méthodes comme decoderJetonManuellement() */
10
	/** Injection de dépendance du service Auth, pour utiliser les méthodes comme decoderJetonManuellement() */
11
	protected $auth;
11
	protected $auth;
12
 
12
 
13
	/** Injection de dépendance de la lib Utilisateur depuis le service Auth */
13
	/** Injection de dépendance de la lib Utilisateur depuis le service Auth */
14
	protected $utilisateur;
14
	protected $utilisateur;
15
 
15
 
16
	/** Jeton brut retourné par le service d'authentification du partenaire */
16
	/** Jeton brut retourné par le service d'authentification du partenaire */
17
	protected $jetonPartenaire;
17
	protected $jetonPartenaire;
18
 
18
 
19
	/** Données décodées depuis le jeton du partenaire */
19
	/** Données décodées depuis le jeton du partenaire */
20
	protected $data;
20
	protected $data;
21
 
21
 
22
	/** Identifiant de l'utilisateur dans l'annuaire local, ou false s'il n'existe pas */
22
	/** Identifiant de l'utilisateur dans l'annuaire local, ou false s'il n'existe pas */
23
	protected $idLocal;
23
	protected $idLocal;
24
 
24
 
25
	public function __construct($authLib) {
25
	public function __construct($authLib) {
26
		$this->auth = $authLib;
26
		$this->auth = $authLib;
27
		$this->utilisateur = $authLib->getUtilisateur();
27
		$this->utilisateur = $authLib->getUtilisateur();
28
		$this->idLocal = false;
28
		$this->idLocal = false;
29
	}
29
	}
30
 
30
 
31
	/** Retourne true si l'utilisateur est authentifié par le partenaire */
31
	/** Retourne true si l'utilisateur est authentifié par le partenaire */
32
	public abstract function verifierAcces($login, $password);
32
	public abstract function verifierAcces($login, $password);
33
 
33
 
34
	/**
34
	/**
35
	 * Vérifie si l'annuaire contient déjà une entrée associée au
35
	 * Vérifie si l'annuaire contient déjà une entrée associée au
36
	 * courriel de l'utilisateur et l'ajoute ou la met à jour au besoin
36
	 * courriel de l'utilisateur et l'ajoute ou la met à jour au besoin
37
	 */
37
	 */
38
	public function synchroniser() {
38
	public function synchroniser() {
39
		$courriel = $this->getCourriel();
39
		$courriel = $this->getCourriel();
40
		// l'utilisateur existe-t-il déjà ?
40
		// l'utilisateur existe-t-il déjà ?
41
		$this->idLocal = $this->utilisateur->getIdParCourriel($courriel);
41
		$this->idLocal = $this->utilisateur->getIdParCourriel($courriel);
42
		if ($this->idLocal !== false) {
42
		if ($this->idLocal !== false) {
43
			if (! $this->profilEstAJour()) {
43
			if (! $this->profilEstAJour()) {
44
				$this->mettreAJourProfil();
44
				$this->mettreAJourProfil();
45
			}
45
			}
46
		} else {
46
		} else {
47
			$this->inscrireUtilisateur();
47
			$this->inscrireUtilisateur();
48
		}
48
		}
49
	}
49
	}
50
 
50
 
51
	/**
51
	/**
52
	 * Retourne true si le profil local est à jour par rapport à la date
52
	 * Retourne true si le profil local est à jour par rapport à la date
53
	 * de dernière modification fournie par le partenaire; si une telle
53
	 * de dernière modification fournie par le partenaire; si une telle
54
	 * date n'existe pas, retourne $retourSiPasDeDate (true par défaut - on
54
	 * date n'existe pas, retourne $retourSiPasDeDate (true par défaut - on
55
	 * ne met pas à jour)
55
	 * ne met pas à jour)
56
	 */
56
	 */
57
	protected function profilEstAJour($retourSiPasDeDate=true) {
57
	protected function profilEstAJour($retourSiPasDeDate=true) {
58
		$tsMajPartenaire = $this->getTimestampMajPartenaire();
58
		$tsMajPartenaire = $this->getTimestampMajPartenaire();
59
		//echo "Timestamp partenaire : "; var_dump($tsMajPartenaire); echo "<br/>";
59
		//echo "Timestamp partenaire : "; var_dump($tsMajPartenaire); echo "<br/>";
60
		if ($tsMajPartenaire != null) {
60
		if ($tsMajPartenaire != null) {
61
			$dateMajLocale = $this->utilisateur->getDateDerniereModifProfil($this->idLocal);
61
			$dateMajLocale = $this->utilisateur->getDateDerniereModifProfil($this->idLocal);
62
			$tsMajLocale = strtotime($dateMajLocale); // attention à ne pas changer le format de date !
62
			$tsMajLocale = strtotime($dateMajLocale); // attention à ne pas changer le format de date !
63
			//echo "Timestamp local : "; var_dump($tsMajLocale); echo "<br/>";
63
			//echo "Timestamp local : "; var_dump($tsMajLocale); echo "<br/>";
64
			return ($tsMajLocale >= $tsMajPartenaire);
64
			return ($tsMajLocale >= $tsMajPartenaire);
65
		}
65
		}
66
		// Si le partenaire ne fournit pas de date, on retourne la valeur par défaut
66
		// Si le partenaire ne fournit pas de date, on retourne la valeur par défaut
67
		return $retourSiPasDeDate;
67
		return $retourSiPasDeDate;
68
	}
68
	}
69
 
69
 
70
	/**
70
	/**
71
	 * Retourne le nom du partenaire en cours
71
	 * Retourne le nom du partenaire en cours
72
	 */
72
	 */
73
	protected abstract function getNomPartenaire();
73
	protected abstract function getNomPartenaire();
74
 
74
 
75
	/**
75
	/**
76
	 * Retourne le courriel de l'utilisateur fourni par le partenaire
76
	 * Retourne le courriel de l'utilisateur fourni par le partenaire
77
	 */
77
	 */
78
	protected abstract function getCourriel();
78
	public abstract function getCourriel();
79
 
79
 
80
	/**
80
	/**
81
	 * Retourne l'identifiant de l'utilisateur fourni par le partenaire
81
	 * Retourne l'identifiant de l'utilisateur fourni par le partenaire
82
	 */
82
	 */
83
	protected abstract function getId();
83
	protected abstract function getId();
84
 
84
 
85
	/**
85
	/**
86
	 * Retourne le timestamp de dernière mise à jour du profil fournie par le
86
	 * Retourne le timestamp de dernière mise à jour du profil fournie par le
87
	 * partenaire; par défaut retourne null, ce qui laisse au mécanisme de
87
	 * partenaire; par défaut retourne null, ce qui laisse au mécanisme de
88
	 * synchronisation le soin de décider si on met à jour le profil ou non
88
	 * synchronisation le soin de décider si on met à jour le profil ou non
89
	 */
89
	 */
90
	protected function getTimestampMajPartenaire() {
90
	protected function getTimestampMajPartenaire() {
91
		return null;
91
		return null;
92
	}
92
	}
93
 
93
 
94
	/**
94
	/**
95
	 * Retourne le jeton fourni par le partenaire
95
	 * Retourne le jeton fourni par le partenaire
96
	 */
96
	 */
97
	public function getJetonPartenaire() {
97
	public function getJetonPartenaire() {
98
		return $this->jetonPartenaire;
98
		return $this->jetonPartenaire;
99
	}
99
	}
100
 
100
 
101
	/**
101
	/**
102
	 * Retourne un tableau de valeurs correpondant au profil de l'utilisateur,
102
	 * Retourne un tableau de valeurs correpondant au profil de l'utilisateur,
103
	 * fourni par le partenaire, et contenant au minimum :
103
	 * fourni par le partenaire, et contenant au minimum :
104
	 * - nom
104
	 * - nom
105
	 * - prenom
105
	 * - prenom
106
	 * - pseudo
106
	 * - pseudo
107
	 * - email
107
	 * - email
108
	 * Pour les autres champs possibles, voir AnnuaireModele::inscrireUtilisateurCommeUnGrosPorc()
108
	 * Pour les autres champs possibles, voir AnnuaireModele::inscrireUtilisateurCommeUnGrosPorc()
109
	 */
109
	 */
110
	protected abstract function getValeursProfilPartenaire();
110
	protected abstract function getValeursProfilPartenaire();
111
 
111
 
112
	protected function inscrireUtilisateur() {
112
	protected function inscrireUtilisateur() {
113
		$valeursProfil = $this->getValeursProfilPartenaire();
113
		$valeursProfil = $this->getValeursProfilPartenaire();
114
		$valeursProfil['partenaire'] = $this->getNomPartenaire();
114
		$valeursProfil['partenaire'] = $this->getNomPartenaire();
115
		$valeursProfil['id_partenaire'] = $this->getId();
115
		$valeursProfil['id_partenaire'] = $this->getId();
116
		// gruik gruik
116
		// gruik gruik
117
		$this->utilisateur->inscrireUtilisateurCommeUnGrosPorc($valeursProfil);
117
		$this->utilisateur->inscrireUtilisateurCommeUnGrosPorc($valeursProfil);
118
	}
118
	}
119
 
119
 
120
	protected function mettreAJourProfil() {
120
	protected function mettreAJourProfil() {
121
		throw new Exception("La mise à jour du profil n'est pas encore prise en charge");
121
		throw new Exception("La mise à jour du profil n'est pas encore prise en charge");
122
		$valeursProfil = $this->getValeursProfilPartenaire();
122
		$valeursProfil = $this->getValeursProfilPartenaire();
123
	}
123
	}
124
}
124
}