Rev 909 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
package org.tela_botanica.client.http;
import org.tela_botanica.client.Mediateur;
import org.tela_botanica.client.composants.InfoLogger;
import org.tela_botanica.client.modeles.Information;
import com.extjs.gxt.ui.client.widget.Info;
import com.google.gwt.core.client.GWT;
import com.google.gwt.http.client.Request;
import com.google.gwt.http.client.RequestCallback;
import com.google.gwt.http.client.Response;
import com.google.gwt.json.client.JSONArray;
import com.google.gwt.json.client.JSONParser;
import com.google.gwt.json.client.JSONValue;
public class JsonRestRequestCallback implements RequestCallback {
public void onError(Request request, Throwable exception) {
// Gestion des exceptions déclenchées par l'exécution de la requête
GWT.log(Mediateur.i18nM.erreurServiceJrest(request.toString()), exception);
InfoLogger.display(Mediateur.i18nM.erreurRequeteTitre(), Mediateur.i18nM.erreurRequete(), true);
}
public void onErrorHTTP(Request request, Response reponse) {
// Gestion des erreurs HTTP renvoyé par Apache ou JRest
Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
InfoLogger.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString(), true);
}
public void onResponseReceived(Request request, Response response) {
// Affichage du débogage.
afficherDebug(response);
// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
if (response.getStatusCode() != 200) {
onErrorHTTP(request, response);
} else {
JSONValue responseValue = null;
if (avoirContenu(response)) {
responseValue = JSONParser.parse(response.getText());
}
surReponse(responseValue);
}
}
public void surReponse(JSONValue responseValue) {
}
public String formaterDeboguages(JSONArray jsonArray) {
String deboguageFormate = "";
for (int i = 0 ; i < jsonArray.size() ; i++) {
if (jsonArray.get(i).isString() != null) {
deboguageFormate += jsonArray.get(i).isString().stringValue()+"\n";
}
}
return deboguageFormate;
}
private void afficherDebug(Response reponse) {
if (avoirEnteteDebug(reponse)) {
final JSONValue reponseEnteteDeboguage = JSONParser.parse(reponse.getHeader("X-DebugJrest-Data"));
if (reponseEnteteDeboguage.isArray() != null) {
GWT.log("DEBOGUAGE:\n"+formaterDeboguages(reponseEnteteDeboguage.isArray()), null);
}
}
}
public Boolean avoirEnteteDebug(Response reponse) {
Boolean retour = false;
if (reponse.getHeader("X-DebugJrest-Data") != null && reponse.getHeader("X-DebugJrest-Data").length() != 0) {
retour = true;
}
return retour;
}
public Boolean avoirContenu(Response reponse) {
Boolean retour = false;
if (reponse.getText() != null && reponse.getText().length() != 0) {
retour = true;
} else if (reponse.getText() == null) {
GWT.log("La réponse vaul null", null);
} else if (reponse.getText().length() == 0) {
GWT.log("La réponse a une taille de 0", null);
}
return retour;
}
}