515 |
aurelien |
1 |
package org.tela_botanica.del.client.services.rest;
|
|
|
2 |
|
530 |
jpm |
3 |
import org.tela_botanica.del.client.config.Config;
|
2077 |
mathias |
4 |
import org.tela_botanica.del.client.modeles.AuthInfo;
|
|
|
5 |
import org.tela_botanica.del.client.modeles.Utilisateur;
|
2054 |
aurelien |
6 |
import org.tela_botanica.del.client.services.rest.async.ActiviteUtilisateurCallback;
|
2077 |
mathias |
7 |
import org.tela_botanica.del.client.services.rest.async.AuthCallback;
|
515 |
aurelien |
8 |
import org.tela_botanica.del.client.services.rest.async.UtilisateurCallback;
|
939 |
benjamin |
9 |
import org.tela_botanica.del.client.services.rest.async.PHPCallback.ModeRequete;
|
1496 |
aurelien |
10 |
import org.tela_botanica.del.client.services.RequestBuilderWithCredentials;
|
2078 |
mathias |
11 |
import org.tela_botanica.del.client.utils.StringUtils;
|
515 |
aurelien |
12 |
|
2077 |
mathias |
13 |
import com.google.gwt.core.shared.GWT;
|
|
|
14 |
import com.google.gwt.user.client.Window;
|
2078 |
mathias |
15 |
import com.google.gwt.user.client.Timer;
|
2077 |
mathias |
16 |
|
515 |
aurelien |
17 |
public class UtilisateurServiceConcret implements UtilisateurService {
|
|
|
18 |
|
530 |
jpm |
19 |
private String baseUrl;
|
2077 |
mathias |
20 |
private String authBaseUrl;
|
2078 |
mathias |
21 |
|
|
|
22 |
private static Timer rafraichisseurJeton = null;
|
530 |
jpm |
23 |
|
|
|
24 |
public UtilisateurServiceConcret() {
|
1470 |
mathias |
25 |
this(new Config());
|
530 |
jpm |
26 |
}
|
|
|
27 |
|
|
|
28 |
public UtilisateurServiceConcret(Config config) {
|
1470 |
mathias |
29 |
this.baseUrl = config.getUrl("serviceUtilisateursBaseUrl");
|
2077 |
mathias |
30 |
this.authBaseUrl = config.getUrl("serviceAuthBaseUrl");
|
530 |
jpm |
31 |
}
|
2077 |
mathias |
32 |
|
|
|
33 |
/**
|
|
|
34 |
* Connecte l'utilisateur en appelant l'annuaire (auth::connexion, SSO), puis enchaîne avec
|
|
|
35 |
* le service "utilisateur" de Del, pour retourner les infos requises par l'interface
|
|
|
36 |
*/
|
515 |
aurelien |
37 |
@Override
|
2077 |
mathias |
38 |
public void connecterUtilisateur(String login, String motDePasse, final UtilisateurCallback callback) {
|
|
|
39 |
RequestBuilderWithCredentials rb = new RequestBuilderWithCredentials(RequestBuilderWithCredentials.GET, authBaseUrl + "connexion?login=" + login + "&password=" + motDePasse);
|
515 |
aurelien |
40 |
try {
|
2077 |
mathias |
41 |
// Callback intermédiaire qui lit les infos de l'annuaire et appelle le service de préférences
|
|
|
42 |
rb.sendRequest(null, new AuthCallback() {
|
|
|
43 |
public void surErreur(String message) {
|
|
|
44 |
// merci, de rien, au revoir messieurs-dames
|
|
|
45 |
callback.surErreur("");
|
|
|
46 |
}
|
|
|
47 |
@Override
|
|
|
48 |
public void surRetour(AuthInfo objetRetour) {
|
2078 |
mathias |
49 |
gererRetourAuthInfo(objetRetour, callback);
|
2077 |
mathias |
50 |
}
|
|
|
51 |
});
|
515 |
aurelien |
52 |
} catch (Exception e) {
|
2077 |
mathias |
53 |
Window.alert("Exception : " + e.getMessage());
|
515 |
aurelien |
54 |
}
|
|
|
55 |
}
|
|
|
56 |
|
2077 |
mathias |
57 |
/**
|
|
|
58 |
* Déconnecte l'utilisateur en appelant l'annuaire (auth::deconnexion, SSO), puis enchaîne avec
|
|
|
59 |
* le service "utilisateur" de Del, pour retourner les infos requises par l'interface
|
|
|
60 |
*/
|
1496 |
aurelien |
61 |
@Override
|
2077 |
mathias |
62 |
public void deconnecterUtilisateur(final UtilisateurCallback callback) {
|
|
|
63 |
RequestBuilderWithCredentials rb = new RequestBuilderWithCredentials(RequestBuilderWithCredentials.GET, authBaseUrl + "deconnexion");
|
515 |
aurelien |
64 |
try {
|
2077 |
mathias |
65 |
// Callback intermédiaire qui lit les infos de l'annuaire et appelle le service de préférences
|
|
|
66 |
rb.sendRequest(null, new AuthCallback() {
|
|
|
67 |
public void surErreur(String message) {
|
|
|
68 |
callback.surErreur("");
|
|
|
69 |
}
|
|
|
70 |
@Override
|
|
|
71 |
public void surRetour(AuthInfo objetRetour) {
|
2078 |
mathias |
72 |
gererRetourAuthInfo(objetRetour, callback);
|
2077 |
mathias |
73 |
}
|
|
|
74 |
});
|
515 |
aurelien |
75 |
} catch (Exception e) {
|
2077 |
mathias |
76 |
GWT.log("Exception : " + e.getMessage());
|
515 |
aurelien |
77 |
}
|
1496 |
aurelien |
78 |
}
|
515 |
aurelien |
79 |
|
2077 |
mathias |
80 |
/**
|
|
|
81 |
* Va chercher les infos de l'utilisateur en vérifiant d'abord l'identité auprès de l'annuaire
|
|
|
82 |
* @param callback
|
|
|
83 |
*/
|
1496 |
aurelien |
84 |
@Override
|
515 |
aurelien |
85 |
public void obtenirUtilisateur(UtilisateurCallback callback) {
|
2077 |
mathias |
86 |
obtenirUtilisateur(callback, false);
|
|
|
87 |
}
|
|
|
88 |
|
|
|
89 |
/**
|
|
|
90 |
* Va chercher les infos de l'utilisateur; si ignorerAnnuaire est false, vérifiera d'abord
|
|
|
91 |
* l'identité auprès de l'annuaire (service annuaire:auth/identite)
|
|
|
92 |
* @param callback
|
|
|
93 |
*/
|
|
|
94 |
@Override
|
|
|
95 |
public void obtenirUtilisateur(final UtilisateurCallback callback, boolean ignorerAnnuaire) {
|
|
|
96 |
// par défaut, on appelle d'abord le service auth/identite de l'annuaire, afin de connaître
|
|
|
97 |
// le statut de l'utilisateur vis à vis du SSO (connecté ou non) et rafraîchir le jeton
|
|
|
98 |
if (! ignorerAnnuaire) {
|
|
|
99 |
RequestBuilderWithCredentials rb = new RequestBuilderWithCredentials(RequestBuilderWithCredentials.GET, authBaseUrl + "identite");
|
|
|
100 |
try {
|
|
|
101 |
rb.sendRequest(null, new AuthCallback() {
|
|
|
102 |
public void surErreur(String message) {
|
|
|
103 |
// Même si l'annuaire n'est pas content, on va chercher un profil utilisateur "anonyme"
|
|
|
104 |
obtenirUtilisateurSansAnnuaire(callback);
|
|
|
105 |
}
|
|
|
106 |
@Override
|
|
|
107 |
public void surRetour(AuthInfo objetRetour) {
|
2078 |
mathias |
108 |
gererRetourAuthInfo(objetRetour, callback);
|
2077 |
mathias |
109 |
}
|
|
|
110 |
});
|
|
|
111 |
} catch (Exception e) {
|
|
|
112 |
// TODO: handle exception
|
|
|
113 |
}
|
|
|
114 |
} else { // sinon on optimise, quand on vient de se (de)connecter, pas la peine de rappeler l'annuaire
|
|
|
115 |
obtenirUtilisateurSansAnnuaire(callback);
|
|
|
116 |
}
|
|
|
117 |
}
|
|
|
118 |
|
|
|
119 |
/**
|
|
|
120 |
* Va chercher les infos de l'utilisateur sans vérifier l'identité auprès de l'annuaire
|
|
|
121 |
* @param callback
|
|
|
122 |
*/
|
|
|
123 |
public void obtenirUtilisateurSansAnnuaire(UtilisateurCallback callback) {
|
1496 |
aurelien |
124 |
RequestBuilderWithCredentials rb = new RequestBuilderWithCredentials(RequestBuilderWithCredentials.GET, baseUrl + "utilisateurs/");
|
515 |
aurelien |
125 |
try {
|
|
|
126 |
rb.sendRequest(null, callback);
|
|
|
127 |
} catch (Exception e) {
|
|
|
128 |
// TODO: handle exception
|
|
|
129 |
}
|
1496 |
aurelien |
130 |
}
|
515 |
aurelien |
131 |
|
2054 |
aurelien |
132 |
@Override
|
|
|
133 |
public void obtenirActiviteUtilisateur(String idUtilisateur, ActiviteUtilisateurCallback callback) {
|
|
|
134 |
RequestBuilderWithCredentials rb = new RequestBuilderWithCredentials(RequestBuilderWithCredentials.GET, baseUrl + "utilisateurs/"+idUtilisateur+"/activite");
|
|
|
135 |
try {
|
|
|
136 |
rb.sendRequest(null, callback);
|
|
|
137 |
} catch (Exception e) {
|
|
|
138 |
// TODO: handle exception
|
|
|
139 |
}
|
|
|
140 |
}
|
|
|
141 |
|
2078 |
mathias |
142 |
/**
|
|
|
143 |
* Enregistre le jeton (potentiellement NULL), sa durée de vie, et appelle
|
|
|
144 |
* le service Del pour obtenir le profil utilisateur associé; lorsque le jeton
|
|
|
145 |
* n'est pas nul et que sa durée de vie est spécifiée, déclenche un rafraîchissement
|
|
|
146 |
* périodique du jeton
|
|
|
147 |
*
|
|
|
148 |
* @param objetRetour le retour de l'appel au service annuaire:auth (connexion, deconnexion ou identite)
|
|
|
149 |
* @param callback
|
|
|
150 |
*/
|
|
|
151 |
protected void gererRetourAuthInfo(AuthInfo objetRetour, UtilisateurCallback callback) {
|
|
|
152 |
// Stockage du jeton rafraîchi et de sa durée (pourrait avoir changé)
|
|
|
153 |
Utilisateur.setJeton(objetRetour.token);
|
|
|
154 |
Utilisateur.setDureeJeton(objetRetour.duration);
|
|
|
155 |
|
|
|
156 |
// Rafraîchissement automatique du jeton - s'annule lorsque le jeton devient nul
|
|
|
157 |
if (Utilisateur.getJeton() != null && Utilisateur.getDureeJeton() > 0) {
|
|
|
158 |
if (rafraichisseurJeton == null) { // on sait jamais
|
|
|
159 |
// 3/4 de la durée de vie du jeton, en millisecondes (ça laisse de la marge)
|
|
|
160 |
int delaiRepetition = (Utilisateur.getDureeJeton() * 1000) * 3 / 4;
|
|
|
161 |
rafraichisseurJeton = new Timer() {
|
|
|
162 |
@Override
|
|
|
163 |
public void run() {
|
|
|
164 |
// Appel de l'annuaire pour rafraîchir le jeton (cb nul pour l'instant)
|
|
|
165 |
// @TODO gérer le possible changement de profil / coordonnées de l'utilisateur
|
|
|
166 |
// en cours de connexion
|
|
|
167 |
obtenirUtilisateur(null);
|
|
|
168 |
}
|
|
|
169 |
};
|
|
|
170 |
rafraichisseurJeton.scheduleRepeating(delaiRepetition);
|
|
|
171 |
}
|
|
|
172 |
} else {
|
|
|
173 |
if (rafraichisseurJeton != null) { // on sait jamais non plus
|
|
|
174 |
rafraichisseurJeton.cancel();
|
|
|
175 |
rafraichisseurJeton = null;
|
|
|
176 |
}
|
|
|
177 |
}
|
|
|
178 |
|
|
|
179 |
// Obtention de l'utilisateur final d'après le service de préférences
|
|
|
180 |
obtenirUtilisateurSansAnnuaire(callback);
|
|
|
181 |
}
|
|
|
182 |
|
515 |
aurelien |
183 |
}
|