463 |
jp_milcent |
1 |
package org.tela_botanica.client.http;
|
|
|
2 |
|
846 |
gduche |
3 |
import org.tela_botanica.client.Mediateur;
|
1225 |
cyprien |
4 |
import org.tela_botanica.client.composants.InfoLogger;
|
463 |
jp_milcent |
5 |
import org.tela_botanica.client.modeles.Information;
|
1563 |
jpm |
6 |
import org.tela_botanica.client.util.Log;
|
463 |
jp_milcent |
7 |
|
|
|
8 |
import com.google.gwt.core.client.GWT;
|
|
|
9 |
import com.google.gwt.http.client.Request;
|
|
|
10 |
import com.google.gwt.http.client.RequestCallback;
|
|
|
11 |
import com.google.gwt.http.client.Response;
|
|
|
12 |
import com.google.gwt.json.client.JSONArray;
|
|
|
13 |
import com.google.gwt.json.client.JSONParser;
|
|
|
14 |
import com.google.gwt.json.client.JSONValue;
|
|
|
15 |
|
|
|
16 |
public class JsonRestRequestCallback implements RequestCallback {
|
|
|
17 |
|
|
|
18 |
public void onError(Request request, Throwable exception) {
|
|
|
19 |
// Gestion des exceptions déclenchées par l'exécution de la requête
|
1563 |
jpm |
20 |
Log.warn(Mediateur.i18nM.erreurServiceJrest(request.toString()), exception);
|
1225 |
cyprien |
21 |
InfoLogger.display(Mediateur.i18nM.erreurRequeteTitre(), Mediateur.i18nM.erreurRequete(), true);
|
463 |
jp_milcent |
22 |
}
|
|
|
23 |
|
|
|
24 |
public void onErrorHTTP(Request request, Response reponse) {
|
|
|
25 |
// Gestion des erreurs HTTP renvoyé par Apache ou JRest
|
1563 |
jpm |
26 |
Information info = null;
|
|
|
27 |
if (avoirContenu(reponse)) {
|
|
|
28 |
info = new Information("erreur_jrest", JSONParser.parseStrict(reponse.getText()).isArray());
|
|
|
29 |
} else {
|
|
|
30 |
info = new Information("erreur_jrest");
|
|
|
31 |
}
|
|
|
32 |
Log.debug("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString());
|
1225 |
cyprien |
33 |
InfoLogger.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString(), true);
|
463 |
jp_milcent |
34 |
}
|
|
|
35 |
|
|
|
36 |
public void onResponseReceived(Request request, Response response) {
|
909 |
jpm |
37 |
// Affichage du débogage.
|
|
|
38 |
afficherDebug(response);
|
|
|
39 |
|
1906 |
mathias |
40 |
// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanisme d'erreur HTTP
|
463 |
jp_milcent |
41 |
if (response.getStatusCode() != 200) {
|
|
|
42 |
onErrorHTTP(request, response);
|
|
|
43 |
} else {
|
|
|
44 |
JSONValue responseValue = null;
|
469 |
jp_milcent |
45 |
if (avoirContenu(response)) {
|
1563 |
jpm |
46 |
responseValue = JSONParser.parseStrict(response.getText());
|
463 |
jp_milcent |
47 |
}
|
|
|
48 |
|
|
|
49 |
surReponse(responseValue);
|
|
|
50 |
}
|
|
|
51 |
}
|
|
|
52 |
|
|
|
53 |
public void surReponse(JSONValue responseValue) {
|
|
|
54 |
}
|
|
|
55 |
|
|
|
56 |
public String formaterDeboguages(JSONArray jsonArray) {
|
|
|
57 |
String deboguageFormate = "";
|
|
|
58 |
|
|
|
59 |
for (int i = 0 ; i < jsonArray.size() ; i++) {
|
|
|
60 |
if (jsonArray.get(i).isString() != null) {
|
|
|
61 |
deboguageFormate += jsonArray.get(i).isString().stringValue()+"\n";
|
|
|
62 |
}
|
|
|
63 |
}
|
|
|
64 |
|
|
|
65 |
return deboguageFormate;
|
|
|
66 |
}
|
469 |
jp_milcent |
67 |
|
909 |
jpm |
68 |
private void afficherDebug(Response reponse) {
|
|
|
69 |
if (avoirEnteteDebug(reponse)) {
|
1563 |
jpm |
70 |
final JSONValue reponseEnteteDeboguage = JSONParser.parseStrict(reponse.getHeader("X-DebugJrest-Data"));
|
909 |
jpm |
71 |
if (reponseEnteteDeboguage.isArray() != null) {
|
|
|
72 |
GWT.log("DEBOGUAGE:\n"+formaterDeboguages(reponseEnteteDeboguage.isArray()), null);
|
|
|
73 |
}
|
|
|
74 |
}
|
|
|
75 |
}
|
|
|
76 |
|
469 |
jp_milcent |
77 |
public Boolean avoirEnteteDebug(Response reponse) {
|
|
|
78 |
Boolean retour = false;
|
|
|
79 |
if (reponse.getHeader("X-DebugJrest-Data") != null && reponse.getHeader("X-DebugJrest-Data").length() != 0) {
|
|
|
80 |
retour = true;
|
|
|
81 |
}
|
|
|
82 |
return retour;
|
|
|
83 |
}
|
|
|
84 |
|
|
|
85 |
public Boolean avoirContenu(Response reponse) {
|
|
|
86 |
Boolean retour = false;
|
|
|
87 |
if (reponse.getText() != null && reponse.getText().length() != 0) {
|
|
|
88 |
retour = true;
|
|
|
89 |
} else if (reponse.getText() == null) {
|
1563 |
jpm |
90 |
Log.debug("La réponse vaul null");
|
469 |
jp_milcent |
91 |
} else if (reponse.getText().length() == 0) {
|
1563 |
jpm |
92 |
Log.debug("La réponse a une taille de 0");
|
469 |
jp_milcent |
93 |
}
|
|
|
94 |
return retour;
|
|
|
95 |
}
|
463 |
jp_milcent |
96 |
}
|