Subversion Repositories eFlore/Applications.coel

Rev

Rev 1415 | Rev 1906 | 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 org.tela_botanica.client.util.Log;

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 
                Log.warn(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 = null;
                if (avoirContenu(reponse)) {
                        info = new Information("erreur_jrest", JSONParser.parseStrict(reponse.getText()).isArray());
                } else {
                        info = new Information("erreur_jrest");
                }
                Log.debug("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString());
                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.parseStrict(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.parseStrict(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) {
                        Log.debug("La réponse vaul null");
                } else if (reponse.getText().length() == 0) {
                        Log.debug("La réponse a une taille de 0");
                }
                return retour;
        }
}