Subversion Repositories Applications.annuaire

Rev

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

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