Subversion Repositories eFlore/Applications.coel

Rev

Rev 1906 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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