Rev 1136 | 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êteGWT.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 JRestInformation 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 HTTPif (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;}}