Subversion Repositories eFlore/Applications.coel

Rev

Rev 245 | Rev 268 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
121 jpm 1
package org.tela_botanica.client.modeles;
2
 
3
import org.tela_botanica.client.RegistreId;
4
import org.tela_botanica.client.interfaces.Rafraichissable;
5
 
6
import com.extjs.gxt.ui.client.Registry;
153 jpm 7
import com.extjs.gxt.ui.client.widget.Info;
133 jpm 8
import com.google.gwt.core.client.GWT;
121 jpm 9
import com.google.gwt.http.client.Request;
10
import com.google.gwt.http.client.RequestBuilder;
11
import com.google.gwt.http.client.RequestCallback;
12
import com.google.gwt.http.client.RequestException;
13
import com.google.gwt.http.client.Response;
14
import com.google.gwt.http.client.URL;
15
import com.google.gwt.json.client.JSONArray;
156 jp_milcent 16
import com.google.gwt.json.client.JSONObject;
121 jpm 17
import com.google.gwt.json.client.JSONParser;
18
import com.google.gwt.json.client.JSONValue;
19
 
20
public class StructureAsyncDao {
264 jp_milcent 21
 
22
	private static final String SERVICE_NOM = "CoelStructureListe";
23
 
24
	public void selectionner(final Rafraichissable vue, String idUtilisateur, final String projetId, final String structureId) {
156 jp_milcent 25
		// Ajout des paramètres et données à selectionner dans l'URL
26
		final String url = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl() +
264 jp_milcent 27
			SERVICE_NOM + "/" +
245 jp_milcent 28
			(projetId == null ? "*" : projetId) + "/" +
264 jp_milcent 29
			(structureId == null ? "*" : structureId) + "/" +
156 jp_milcent 30
			"";
31
 
32
		RequestBuilder rb = new RequestBuilder(RequestBuilder.GET, url);
33
		try {
34
			rb.sendRequest(null, new RequestCallback() {
35
 
36
				public void onError(Request request, Throwable exception) {
37
					// Gestion des exceptions déclenchées par l'exécution de la requête
38
					GWT.log("Erreur à l'exécution du service CoelStructureListe (selection)", exception);
39
					Info.display("Erreur de Requête", "Une erreur s'est produite lors de l'exécution de la requête.");
40
				}
41
 
42
				public void onErrorHTTP(Request request, Response reponse) {
43
					// Gestion des erreurs HTTP renvoyé par Apache ou JRest
44
					Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
45
					GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
46
					Info.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString());
47
				}
48
 
49
				public void onResponseReceived(Request request, Response response) {
50
					// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
51
					if (response.getStatusCode() != 200) {
52
						onErrorHTTP(request, response);
53
					} else {
54
						if (response.getText().length() != 0 && response.getText() != null) {
55
							final JSONValue responseValue = JSONParser.parse(response.getText());
56
 
57
							// Si la requête est un succès, reception d'un objet ou d'un tableau
58
							if (responseValue.isObject() != null) {
59
								final JSONObject reponse = responseValue.isObject();
60
								// Transformation du tableau JSON réponse en ListeInstitution
61
								Structure structure = new Structure(reponse);
188 jp_milcent 62
								StructureConservation structureConservation = new StructureConservation(reponse);
192 jp_milcent 63
								StructureValorisation structureValorisation = new StructureValorisation(reponse);
188 jp_milcent 64
								Information info = new Information("selection_structure");
65
								info.setDonnee(0, structure);
66
								info.setDonnee(1, structureConservation);
192 jp_milcent 67
								info.setDonnee(2, structureValorisation);
264 jp_milcent 68
								vue.rafraichir(info);
156 jp_milcent 69
							} else if (responseValue.isArray() != null) {
70
								final JSONArray reponse = responseValue.isArray();
71
								// Transformation du tableau JSON réponse en ListeInstitution
72
								StructureListe structures = new StructureListe(reponse);
73
								// et on met à jour le demandeur des données
264 jp_milcent 74
								vue.rafraichir(structures);
156 jp_milcent 75
							} else {
76
								GWT.log(url+"\n\tLa réponse n'est pas un objet ou un talbeau JSON et vaut : "+responseValue.toString(), null);
77
							}
78
						} else {
264 jp_milcent 79
							if (structureId == null) {
156 jp_milcent 80
								// Dans le cas, où nous demandons toutes les institutions et qu'il n'y en a pas, nous retournons un objet vide
81
								StructureListe structures = new StructureListe(0);
264 jp_milcent 82
								vue.rafraichir(structures);
156 jp_milcent 83
							} else {
84
								GWT.log(url, null);
85
								if (response.getText().length() == 0) {
86
									GWT.log("\tLa réponse a une taille de 0", null);
87
								}
88
								if (response.getText() == null) {
89
									GWT.log("\tLa réponse vaul null", null);
90
								}
91
							}
92
						}
93
					}
94
				}
95
			});
96
		} catch (RequestException e) {
97
			e.printStackTrace();
98
		}
99
	}
100
 
121 jpm 101
	public void ajouter(final Rafraichissable r, String utilisateurId, final Structure str) {
153 jpm 102
		final String url = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl() +
264 jp_milcent 103
			SERVICE_NOM + "/" +
104
			"";
121 jpm 105
 
153 jpm 106
		RequestBuilder rb = new RequestBuilder(RequestBuilder.POST, url);
107
 
140 jpm 108
		String postDonnees = 	"cmhl_ce_modifier_par=" + utilisateurId +
264 jp_milcent 109
			"&cs_ce_projet=" + URL.encodeComponent(str.getIdProjet()) +
110
			"&cs_ce_mere=" + URL.encodeComponent(str.getIdMere()) +
111
			"&cs_guid=" + URL.encodeComponent(str.getGuid()) +
112
			"&cs_truk_identifiant_alternatif=" + URL.encodeComponent(str.getIdAlternatif()) +
140 jpm 113
			"&cs_nom=" + URL.encodeComponent(str.getNom()) +
264 jp_milcent 114
			"&cs_truk_nom_alternatif=" + URL.encodeComponent(str.getNomAlternatif()) +
115
			"&cs_ce_type=" + URL.encodeComponent(str.getType()) +
116
			"&cs_ce_truk_type_prive=" + URL.encodeComponent(str.getTypePrive()) +
117
			"&cs_ce_truk_type_public=" + URL.encodeComponent(str.getTypePublic()) +
118
			"&cs_adresse_01=" + URL.encodeComponent(str.getAdresse()) +
119
			"&cs_adresse_02=" + URL.encodeComponent(str.getAdresseComplement()) +
120
			"&cs_date_fondation=" + URL.encodeComponent(str.getDateFondationFormatMysql()) +
121
			"&cs_code_postal=" + URL.encodeComponent(str.getCodePostal()) +
122
			"&cs_ville=" + URL.encodeComponent(str.getVille()) +
123
			"&cs_region=" + URL.encodeComponent(str.getRegion()) +
124
			"&cs_pays=" + URL.encodeComponent(str.getPays()) +
125
			"&cs_telephone=" + URL.encodeComponent(str.getTelephone()) +
126
			"&cs_fax=" + URL.encodeComponent(str.getFax()) +
127
			"&cs_truk_url=" + URL.encodeComponent(str.getUrl()) +
128
			"&cs_nbre_personne=" + URL.encodeComponent(Integer.toString(str.getNbrePersonne())) +
121 jpm 129
			"";
130
 
131
		try {
132
			rb.sendRequest(postDonnees, new RequestCallback() {
133
 
134
				public void onError(Request request, Throwable exception) {
153 jpm 135
					// Gestion des exceptions déclenchées par l'exécution de la requête
156 jp_milcent 136
					GWT.log("Erreur à l'exécution du service CoelStructureListe (ajout)", exception);
153 jpm 137
					Info.display("Erreur de Requête", "Une erreur s'est produite lors de l'exécution de la requête.");
121 jpm 138
				}
153 jpm 139
 
140
				public void onErrorHTTP(Request request, Response reponse) {
141
					// Gestion des erreurs HTTP renvoyé par Apache ou JRest
142
					Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
143
					GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
144
					Info.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString());
145
				}
121 jpm 146
 
147
				public void onResponseReceived(Request request, Response response) {
153 jpm 148
					// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
149
					if (response.getStatusCode() != 200) {
150
						onErrorHTTP(request, response);
151
					} else {
152
						if (response.getText().length() != 0 && response.getText() != null) {
153
							final JSONValue responseValue = JSONParser.parse(response.getText());
154
 
155 jpm 155
							// Si la requête est un succès, reception d'une chaine
156
							if (responseValue.isString() != null) {
157
								Information info = new Information("ajout_structure", responseValue.isString().stringValue());
153 jpm 158
								r.rafraichir(info);
159
							} else {
155 jpm 160
								GWT.log(url+"\n\tLa réponse n'est pas une chaine JSON.", null);
153 jpm 161
							}
162
						} else {
163
							GWT.log(url, null);
164
							if (response.getText().length() == 0) {
165
								GWT.log("\tLa réponse a une taille de 0", null);
166
							}
167
							if (response.getText() == null) {
168
								GWT.log("\tLa réponse vaul null", null);
169
							}
121 jpm 170
						}
171
					}
172
				}
173
 
174
			}) ;
175
		} catch (RequestException e) {
153 jpm 176
			// Gestion des exceptions déclenchées par la création de la requête (url non-valide ?)
177
			GWT.log("Erreur à la création du service CoelProjetsListe", e);
178
			Info.display("Erreur de Requête", "Une erreur s'est produite lors de la création de la requête.");
121 jpm 179
		}
180
	}
133 jpm 181
 
264 jp_milcent 182
	public void supprimer(final Rafraichissable r, String utilisateurId, String structureId) {
133 jpm 183
		// Ajout des paramètres et données à supprimer dans l'URL
184
		final String url = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl() +
264 jp_milcent 185
			SERVICE_NOM + "/" +
186
			utilisateurId + "/" +
187
			structureId +
133 jpm 188
			"";
189
 
190
		// DELETE n'étant pas disponible comme méthode HTTP, nous utilisons POST avec le paramètre action=DELETE
191
		RequestBuilder rb = new RequestBuilder(RequestBuilder.POST, url);
192
		String postDonnees = "action=DELETE";
193
 
194
		try {
195
			rb.sendRequest(postDonnees, new RequestCallback() {
196
 
197
				public void onError(Request request, Throwable exception) {
156 jp_milcent 198
					// Gestion des exceptions déclenchées par l'exécution de la requête
199
					GWT.log("Erreur à l'exécution du service CoelStructureListe (suppression)", exception);
200
					Info.display("Erreur de Requête", "Une erreur s'est produite lors de l'exécution de la requête.");
133 jpm 201
				}
202
 
153 jpm 203
				public void onErrorHTTP(Request request, Response reponse) {
204
					// Gestion des erreurs HTTP renvoyé par Apache ou JRest
205
					Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
206
					GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
207
					Info.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString());
208
				}
209
 
133 jpm 210
				public void onResponseReceived(Request request, Response response) {
153 jpm 211
					// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
212
					if (response.getStatusCode() != 200) {
213
						onErrorHTTP(request, response);
214
					} else {
215
						if (response.getText().length() != 0 && response.getText() != null) {
216
							final JSONValue responseValue = JSONParser.parse(response.getText());
217
 
156 jp_milcent 218
							// Si la requête est un succès, reception d'une chaine
153 jpm 219
							if (responseValue.isString() != null) {
220
								Information info = new Information("suppression_structure", responseValue.isString().stringValue());
221
								r.rafraichir(info);
222
							} else {
223
								GWT.log(url+"\n\tLa réponse n'est pas une chaine JSON.", null);
224
							}
133 jpm 225
						} else {
153 jpm 226
							GWT.log(url, null);
227
							if (response.getText().length() == 0) {
228
								GWT.log("\tLa réponse a une taille de 0", null);
229
							}
230
							if (response.getText() == null) {
231
								GWT.log("\tLa réponse vaul null", null);
232
							}
133 jpm 233
						}
234
					}
235
				}
236
 
237
			}) ;
238
		} catch (RequestException e) {
153 jpm 239
			// Gestion des exceptions déclenchées par la création de la requête (url non-valide ?)
240
			GWT.log("Erreur à la création du service CoelProjetsListe", e);
241
			Info.display("Erreur de Requête", "Une erreur s'est produite lors de la création de la requête.");
133 jpm 242
		}
243
	}
169 jp_milcent 244
 
192 jp_milcent 245
	public void modifier(final Rafraichissable r, String utilisateurId, Structure str, StructureConservation conservation, StructureValorisation valorisation) {
169 jp_milcent 246
		final String url = ((Configuration) Registry.get(RegistreId.CONFIG)).getServiceBaseUrl() +
264 jp_milcent 247
		SERVICE_NOM + "/" +
169 jp_milcent 248
		str.getId()
249
		;
250
 
251
		RequestBuilder rb = new RequestBuilder(RequestBuilder.POST, url);
252
 
253
		String postDonnees = 	"cmhl_ce_modifier_par=" + utilisateurId +
264 jp_milcent 254
			"&cs_ce_projet=" + URL.encodeComponent(str.getIdProjet()) +
255
			"&cs_ce_mere=" + URL.encodeComponent(str.getIdMere()) +
256
			"&cs_guid=" + URL.encodeComponent(str.getGuid()) +
257
			"&cs_truk_identifiant_alternatif=" + URL.encodeComponent(str.getIdAlternatif()) +
169 jp_milcent 258
			"&cs_nom=" + URL.encodeComponent(str.getNom()) +
264 jp_milcent 259
			"&cs_truk_nom_alternatif=" + URL.encodeComponent(str.getNomAlternatif()) +
260
			"&cs_ce_type=" + URL.encodeComponent(str.getType()) +
261
			"&cs_ce_truk_type_prive=" + URL.encodeComponent(str.getTypePrive()) +
262
			"&cs_ce_truk_type_public=" + URL.encodeComponent(str.getTypePublic()) +
263
			"&cs_adresse_01=" + URL.encodeComponent(str.getAdresse()) +
264
			"&cs_adresse_02=" + URL.encodeComponent(str.getAdresseComplement()) +
265
			"&cs_date_fondation=" + URL.encodeComponent(str.getDateFondationFormatMysql()) +
266
			"&cs_code_postal=" + URL.encodeComponent(str.getCodePostal()) +
267
			"&cs_ville=" + URL.encodeComponent(str.getVille()) +
268
			"&cs_region=" + URL.encodeComponent(str.getRegion()) +
269
			"&cs_pays=" + URL.encodeComponent(str.getPays()) +
270
			"&cs_telephone=" + URL.encodeComponent(str.getTelephone()) +
271
			"&cs_fax=" + URL.encodeComponent(str.getFax()) +
272
			"&cs_courriel=" + URL.encodeComponent(str.getCourriel()) +
273
			"&cs_truk_url=" + URL.encodeComponent(str.getUrl()) +
274
			"&cs_nbre_personne=" + URL.encodeComponent(Integer.toString(str.getNbrePersonne())) +
275
			"&csc_mark_formation=" + URL.encodeComponent(conservation.getFormation()) +
276
			"&csc_formation=" + URL.encodeComponent(conservation.getFormationInfo()) +
277
			"&csc_mark_formation_interet=" + URL.encodeComponent(conservation.getFormationInteret()) +
278
			"&csc_truk_stockage_local=" + URL.encodeComponent(conservation.getStockageLocal()) +
279
			"&csc_truk_stockage_meuble=" + URL.encodeComponent(conservation.getStockageMeuble()) +
280
			"&csc_truk_stockage_parametre=" + URL.encodeComponent(conservation.getStockageParametre()) +
281
			"&csc_mark_collection_commune=" + URL.encodeComponent(conservation.getCollectionCommune()) +
282
			"&csc_truk_collection_autre=" + URL.encodeComponent(conservation.getCollectionAutre()) +
283
			"&csc_mark_acces_controle=" + URL.encodeComponent(conservation.getAccesControle()) +
284
			"&csc_mark_restauration=" + URL.encodeComponent(conservation.getRestauration()) +
285
			"&csc_truk_restauration_operation=" + URL.encodeComponent(conservation.getRestaurationOperation()) +
286
			"&csc_ce_materiel_conservation=" + URL.encodeComponent(conservation.getMaterielConservation()) +
287
			"&csc_truk_materiel_autre=" + URL.encodeComponent(conservation.getMaterielAutre()) +
288
			"&csc_mark_traitement=" + URL.encodeComponent(conservation.getTraitement()) +
289
			"&csc_truk_traitement=" + URL.encodeComponent(conservation.getTraitements()) +
290
			"&csc_mark_acquisition_collection=" + URL.encodeComponent(conservation.getAcquisitionCollection()) +
291
			"&csc_mark_acquisition_echantillon=" + URL.encodeComponent(conservation.getAcquisitionEchantillon()) +
292
			"&csc_mark_acquisition_traitement=" + URL.encodeComponent(conservation.getAcquisitionTraitement()) +
293
			"&csc_truk_acquisition_traitement_poison=" + URL.encodeComponent(conservation.getAcquisitionTraitementPoison()) +
294
			"&csc_truk_acquisition_traitement_insecte=" + URL.encodeComponent(conservation.getAcquisitionTraitementInsecte()) +
295
			"&csv_mark_action=" + URL.encodeComponent(valorisation.getAction()) +
296
			"&csv_truk_action=" + URL.encodeComponent(valorisation.getActionInfo()) +
297
			"&csv_publication=" + URL.encodeComponent(valorisation.getPublication()) +
298
			"&csv_collection_autre=" + URL.encodeComponent(valorisation.getCollectionAutre()) +
299
			"&csv_mark_action_future=" + URL.encodeComponent(valorisation.getActionFuture()) +
300
			"&csv_action_future=" + URL.encodeComponent(valorisation.getActionFutureInfo()) +
301
			"&csv_mark_recherche=" + URL.encodeComponent(valorisation.getRecherche()) +
302
			"&csv_truk_recherche_provenance=" + URL.encodeComponent(valorisation.getRechercheProvenance()) +
303
			"&csv_truk_recherche_type=" + URL.encodeComponent(valorisation.getRechercheType()) +
304
			"&csv_mark_acces_ss_motif=" + URL.encodeComponent(valorisation.getAccesSansMotif()) +
305
			"&csv_acces_ss_motif=" + URL.encodeComponent(valorisation.getAccesSansMotifInfo()) +
306
			"&csv_mark_visite_avec_motif=" + URL.encodeComponent(valorisation.getVisiteAvecMotif()) +
307
			"&csv_visite_avec_motif=" + URL.encodeComponent(valorisation.getVisiteAvecMotifInfo()) +
169 jp_milcent 308
			"";
309
 
310
		try {
311
			rb.sendRequest(postDonnees, new RequestCallback() {
312
 
313
				public void onError(Request request, Throwable exception) {
314
					// Gestion des exceptions déclenchées par l'exécution de la requête
315
					GWT.log("Erreur à l'exécution du service CoelStructureListe (modif)", exception);
316
					Info.display("Erreur de Requête", "Une erreur s'est produite lors de l'exécution de la requête.");
317
				}
318
 
319
				public void onErrorHTTP(Request request, Response reponse) {
320
					// Gestion des erreurs HTTP renvoyé par Apache ou JRest
321
					Information info = new Information("erreur_jrest", JSONParser.parse(reponse.getText()).isArray());
322
					GWT.log("Erreur JREST - Code "+reponse.getStatusCode()+"\n"+info.getMessages().toString(), null);
323
					Info.display("Erreur JREST - Code "+reponse.getStatusCode(), info.toString());
324
				}
325
 
326
				public void onResponseReceived(Request request, Response response) {
327
					// Si le code de réponse HTTP ne vaut pas 200 OK, on lance le mécanise d'erreur HTTP
328
					if (response.getStatusCode() != 200) {
329
						onErrorHTTP(request, response);
330
					} else {
331
						if (response.getText().length() != 0 && response.getText() != null) {
332
							final JSONValue responseValue = JSONParser.parse(response.getText());
333
 
334
							// Si la requête est un succès, reception d'une chaine
335
							if (responseValue.isString() != null) {
336
								Information info = new Information("modif_structure", responseValue.isString().stringValue());
337
								r.rafraichir(info);
338
							} else {
339
								GWT.log(url+"\n\tLa réponse n'est pas une chaine JSON.", null);
340
							}
341
						} else {
342
							GWT.log(url, null);
343
							if (response.getText().length() == 0) {
344
								GWT.log("\tLa réponse a une taille de 0", null);
345
							}
346
							if (response.getText() == null) {
347
								GWT.log("\tLa réponse vaul null", null);
348
							}
349
						}
350
					}
351
				}
352
 
353
			}) ;
354
		} catch (RequestException e) {
355
			// Gestion des exceptions déclenchées par la création de la requête (url non-valide ?)
356
			GWT.log("Erreur à la création du service CoelProjetsListe", e);
357
			Info.display("Erreur de Requête", "Une erreur s'est produite lors de la création de la requête.");
358
		}
359
	}
121 jpm 360
}