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 |
}
|