Subversion Repositories eFlore/Applications.coel

Rev

Rev 1417 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 1417 Rev 1468
1
package org.tela_botanica.client.modeles.projet;
1
package org.tela_botanica.client.modeles.projet;
2
 
2
 
3
import java.util.HashMap;
3
import java.util.HashMap;
4
 
4
 
5
import org.tela_botanica.client.Mediateur;
5
import org.tela_botanica.client.Mediateur;
6
import org.tela_botanica.client.RegistreId;
6
import org.tela_botanica.client.RegistreId;
7
import org.tela_botanica.client.http.JsonRestRequestBuilder;
7
import org.tela_botanica.client.http.JsonRestRequestBuilder;
8
import org.tela_botanica.client.http.JsonRestRequestCallback;
8
import org.tela_botanica.client.http.JsonRestRequestCallback;
9
import org.tela_botanica.client.interfaces.Rafraichissable;
9
import org.tela_botanica.client.interfaces.Rafraichissable;
10
import org.tela_botanica.client.modeles.Information;
10
import org.tela_botanica.client.modeles.Information;
11
import org.tela_botanica.client.modeles.structure.StructureListe;
11
import org.tela_botanica.client.modeles.structure.StructureListe;
12
import org.tela_botanica.client.synchronisation.Reponse;
12
import org.tela_botanica.client.synchronisation.Reponse;
-
 
13
import org.tela_botanica.client.util.Debug;
13
import org.tela_botanica.client.util.UtilDAO;
14
import org.tela_botanica.client.util.UtilDAO;
14
 
15
 
15
import com.extjs.gxt.ui.client.Registry;
16
import com.extjs.gxt.ui.client.Registry;
16
import com.extjs.gxt.ui.client.widget.Info;
17
import com.extjs.gxt.ui.client.widget.Info;
17
import com.google.gwt.core.client.GWT;
18
import com.google.gwt.core.client.GWT;
18
import com.google.gwt.json.client.JSONArray;
19
import com.google.gwt.json.client.JSONArray;
19
import com.google.gwt.json.client.JSONObject;
20
import com.google.gwt.json.client.JSONObject;
20
import com.google.gwt.json.client.JSONValue;
21
import com.google.gwt.json.client.JSONValue;
21
 
22
 
22
public class ProjetAsyncDao {
23
public class ProjetAsyncDao {
23
	private static final String SERVICE_NOM = "CoelProjet";
24
	private static final String SERVICE_NOM = "CoelProjet";
24
	
25
	
25
	String utilisateurId = null;
26
	String utilisateurId = null;
26
	private Rafraichissable vueARafraichir = null;
27
	private Rafraichissable vueARafraichir = null;
27
	
28
	
28
	public ProjetAsyncDao(Rafraichissable vueARafraichirCourrante) {
29
	public ProjetAsyncDao(Rafraichissable vueARafraichirCourrante) {
29
		if (Mediateur.DEBUG) System.out.println("|| ProjetAsyncDao > vueARafraichir = "+vueARafraichirCourrante.getClass().toString());
30
		if (Mediateur.DEBUG) System.out.println("|| ProjetAsyncDao > vueARafraichir = "+vueARafraichirCourrante.getClass().toString());
30
		vueARafraichir = vueARafraichirCourrante;
31
		vueARafraichir = vueARafraichirCourrante;
31
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
32
		utilisateurId = ((Mediateur) Registry.get(RegistreId.MEDIATEUR)).getUtilisateurId();
32
	}
33
	}
33
 
34
 
34
	
35
	
35
	/**
36
	/**
36
	 * @param paginationProgressive : définit le mode de consultation de la base de données
37
	 * @param paginationProgressive : définit le mode de consultation de la base de données
37
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
38
	 * 			- True :	la consultation des données est progressive, ce qui signifie que la liste est chargée (paginée) au
38
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
39
	 * 						fur et à mesure de la consultation des données par l'utilisateur.
39
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
40
	 * 			- False :	la consultation des données est classique : un seul appel à la base de données est effectué, le retour
40
	 * 						est renvoyé à l'appelant
41
	 * 						est renvoyé à l'appelant
41
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
42
	 * 			// FIXME : si la taille de la liste est supérieure à la limite du JREST (150), ce deuxieme mode ne fonctionne pas
42
	 */
43
	 */
43
	public void selectionner(final boolean paginationProgressive, final String projetId, final String nomProjet, final int start, final int nbElements, final Integer seqId) {
44
	public void selectionner(final boolean paginationProgressive, final String projetId, final String nomProjet, final int start, final int nbElements, final String formatRetour, final Integer seqId) {
44
		
45
		
45
		String nom = (nomProjet == null) ? "%" : nomProjet+"%";
46
		String nom = (nomProjet == null) ? "%" : nomProjet+"%";
46
		String[] param = {projetId, nom};
47
		String[] param = {projetId, nom};
47
		
48
		
48
		HashMap<String, String> restrictions = new HashMap<String, String>();
49
		HashMap<String, String> restrictions = new HashMap<String, String>();
49
		
50
		
50
		if (nbElements != -1)	{
51
		if (nbElements != -1) {
51
			restrictions.put("limit", String.valueOf(nbElements));
52
			restrictions.put("limit", String.valueOf(nbElements));
-
 
53
		}
-
 
54
 
-
 
55
		if ((formatRetour != null) && (formatRetour != "")) {
-
 
56
			restrictions.put("formatRetour", formatRetour);
52
		}
57
		}
53
		
58
		
54
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
59
		/** GESTION DE LA REQUETE dans le cas d'une liste paginée progressive **/
55
		if (paginationProgressive) {
60
		if (paginationProgressive) {
56
 
61
 
57
			/** DEFINITION DU TUPLE DE DEPART **/
62
			/** DEFINITION DU TUPLE DE DEPART **/
58
			restrictions.put("start", String.valueOf(start));
63
			restrictions.put("start", String.valueOf(start));
59
			
64
			
60
			/** CONSTRUCTION DE LA REQUETE **/
65
			/** CONSTRUCTION DE LA REQUETE **/
61
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, param, restrictions);
66
    		final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, param, restrictions);
62
 
67
 
63
    		/** ENVOI DE LA REQUETE **/
68
    		/** ENVOI DE LA REQUETE **/
64
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
69
    		rb.envoyerRequete(null, new JsonRestRequestCallback()
65
    		{
70
    		{
66
    			/** RECEPTION DE LA REPONSE **/
71
    			/** RECEPTION DE LA REPONSE **/
67
    			public void surReponse(JSONValue responseValue)
72
    			public void surReponse(JSONValue responseValue)
68
    			{
73
    			{
69
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
74
    				/** Dans le cas d'une liste paginée, vueARafraichir est un objet Proxy.
70
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
75
    				 * On retourne l'objet JSON au proxy afin que ce soit lui qui le traite **/
71
					if (seqId != null)	{
76
					if (seqId != null)	{
72
						Reponse reponseRequete = new Reponse(responseValue, seqId);
77
						Reponse reponseRequete = new Reponse(responseValue, seqId);
73
						vueARafraichir.rafraichir(reponseRequete);
78
						vueARafraichir.rafraichir(reponseRequete);
74
					}
79
					}
75
					else	{
80
					else	{
76
						vueARafraichir.rafraichir(responseValue);
81
						vueARafraichir.rafraichir(responseValue);
77
					}
82
					}
78
    			}
83
    			}
79
    		});
84
    		});
80
		}
85
		}
81
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
86
		/** GESTION DE LA REQUETE dans le cas d'une liste NON paginée progressive **/
82
		else {
87
		else {
83
			
88
			
84
			/** DEFINITION DU TUPLE DE DEPART **/
89
			/** DEFINITION DU TUPLE DE DEPART **/
85
			restrictions.put("start", String.valueOf(start*nbElements));			
90
			restrictions.put("start", String.valueOf(start*nbElements));			
86
			
91
			
87
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, param, restrictions);
92
			final JsonRestRequestBuilder rb = UtilDAO.construireRequete(SERVICE_NOM, param, restrictions);
88
			
93
			
89
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
94
			rb.envoyerRequete(null, new JsonRestRequestCallback() {
90
				
95
				
91
				public void surReponse(JSONValue responseValue) {
96
				public void surReponse(JSONValue responseValue) {
92
					
97
    				
93
					if (responseValue != null) {
98
					if (responseValue != null) {
94
						
99
						
95
						JSONObject responseObject = responseValue.isObject();
100
						JSONObject responseObject = responseValue.isObject();
96
						
101
						
97
						if (responseObject != null) {
102
						if (responseObject != null) {
98
							
103
							
99
							// Si la réponse est un tableau, alors c'est une liste de projets qui a été retournée
104
							// Si la réponse est un tableau, alors c'est une liste de projets qui a été retournée
100
							if (responseObject.get("projets").isArray() != null) {
105
							if (responseObject.get("projets").isArray() != null) {
101
								
106
								
102
								JSONArray reponse = responseObject.get("projets").isArray();
107
								JSONArray reponse = responseObject.get("projets").isArray();
103
								ProjetListe projets;
108
								ProjetListe projets;
104
								projets = new ProjetListe(reponse, responseObject.get("nbElements").isNumber(), vueARafraichir);
109
								projets = new ProjetListe(reponse, responseObject.get("nbElements").isNumber(), vueARafraichir);
105
								projets.setTaillePage(nbElements);
110
								projets.setTaillePage(nbElements);
106
								projets.setPageCourante(start);							
111
								projets.setPageCourante(start);							
107
								
112
 
108
								if (seqId != null)	{
113
								if (seqId != null) {
109
									Reponse retourRequete = new Reponse(projets, seqId);
114
									Reponse retourRequete = new Reponse(projets, seqId);
110
									vueARafraichir.rafraichir(retourRequete);
115
									vueARafraichir.rafraichir(retourRequete);
111
								} else {
116
								} else {
112
									vueARafraichir.rafraichir(projets);
117
									vueARafraichir.rafraichir(projets);
113
								}
118
								}
114
							
119
							
115
							// Si la réponse est un objet, alors c'est un unique projet qui a été retournée
120
							// Si la réponse est un objet, alors c'est un unique projet qui a été retourné
116
							} else if (responseObject.get("projets").isObject() != null) {
121
							} else if (responseObject.get("projets").isObject() != null) {
117
								
122
								
118
								JSONObject reponse = responseObject.get("projets").isObject();
123
								JSONObject reponse = responseObject.get("projets").isObject();
119
								Projet projet = new Projet(reponse);
124
								Projet projet = new Projet(reponse);
120
								
125
								
121
								Information info = new Information("selection_projet");
126
								Information info = new Information("selection_projet");
122
								info.setDonnee(0, projet);
127
								info.setDonnee(0, projet);
123
								
128
 
124
								if (seqId != null)	{
129
								if (seqId != null) {
125
									Reponse reponseRequete = new Reponse(info, seqId);
130
									Reponse reponseRequete = new Reponse(info, seqId);
126
									vueARafraichir.rafraichir(reponseRequete);
131
									vueARafraichir.rafraichir(reponseRequete);
127
								}
132
								}
128
								else	{
133
								else {
129
									vueARafraichir.rafraichir(info);
134
									vueARafraichir.rafraichir(info);
130
								}
135
								}
131
							}
136
							}
132
						} else {
137
						} else {
133
							GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un objet ou un tableau JSON et vaut : "+responseValue.toString(), null);
138
							GWT.log(rb.getUrl()+"\n\tLa réponse n'est pas un objet ou un tableau JSON et vaut : "+responseValue.toString(), null);
134
						}
139
						}
135
					} else {
140
					} else {
136
						// Dans le cas, où nous demandons tous les projets et qu'il n'y en a pas, nous retournons un objet vide
141
						// Dans le cas, où nous demandons tous les projets et qu'il n'y en a pas, nous retournons un objet vide
137
						if (projetId == null) {
142
						if (projetId == null) {
138
							ProjetListe projets = new ProjetListe(0);
143
							ProjetListe projets = new ProjetListe(0);
139
							if (seqId != null)	{
144
							if (seqId != null)	{
140
								Reponse reponseRequete = new Reponse(projets, seqId);
145
								Reponse reponseRequete = new Reponse(projets, seqId);
141
								vueARafraichir.rafraichir(reponseRequete);
146
								vueARafraichir.rafraichir(reponseRequete);
142
							}
147
							}
143
							else	{
148
							else	{
144
								vueARafraichir.rafraichir(projets);
149
								vueARafraichir.rafraichir(projets);
145
							}						
150
							}						
146
						}
151
						}
147
					}
152
					}
148
				}
153
				}
149
			});
154
			});
150
		}		
155
		}		
151
	}
156
	}
152
	
157
	
153
	public void ajouter(Projet projet) {
158
	public void ajouter(Projet projet) {
154
		String postDonneesEncodees = projet.obtenirChainePOST()+"&cmhl_ce_modifier_par="+utilisateurId;
159
		String postDonneesEncodees = projet.obtenirChainePOST()+"&cmhl_ce_modifier_par="+utilisateurId;
155
		
160
		
156
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM);
161
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM);
157
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
162
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
158
			@Override
163
			@Override
159
			public void surReponse(JSONValue reponseValeur) {
164
			public void surReponse(JSONValue reponseValeur) {
160
				traiterReponse(reponseValeur, "ajout_projet");
165
				traiterReponse(reponseValeur, "ajout_projet");
161
			}
166
			}
162
		}) ;
167
		}) ;
163
	}
168
	}
164
	
169
	
165
	public void modifier(Projet projet) {
170
	public void modifier(Projet projet) {
166
		String[] parametres = {projet.getId()};
171
		String[] parametres = {projet.getId()};
167
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
172
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
168
		
173
		
169
		String postDonneesEncodees = projet.obtenirChainePOST()+"&cmhl_ce_modifier_par="+utilisateurId;
174
		String postDonneesEncodees = projet.obtenirChainePOST()+"&cmhl_ce_modifier_par="+utilisateurId;
170
		
175
		
171
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
176
		rb.envoyerRequete(postDonneesEncodees, new JsonRestRequestCallback() {
172
			@Override
177
			@Override
173
			public void surReponse(JSONValue reponseValeur) {
178
			public void surReponse(JSONValue reponseValeur) {
174
				traiterReponse(reponseValeur, "modif_projet");
179
				traiterReponse(reponseValeur, "modif_projet");
175
			}
180
			}
176
		});
181
		});
177
	}
182
	}
178
 
183
 
179
	public void supprimer(String projetsId) {
184
	public void supprimer(String projetsId) {
180
		String[] parametres = {utilisateurId, projetsId};
185
		String[] parametres = {utilisateurId, projetsId};
181
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
186
		final JsonRestRequestBuilder rb = UtilDAO.construireRequetePost(SERVICE_NOM, parametres);
182
		rb.envoyerRequeteSuppression(new JsonRestRequestCallback() {
187
		rb.envoyerRequeteSuppression(new JsonRestRequestCallback() {
183
			@Override
188
			@Override
184
			public void surReponse(JSONValue reponseValeur) {
189
			public void surReponse(JSONValue reponseValeur) {
185
				traiterReponse(reponseValeur, "suppression_projet");
190
				traiterReponse(reponseValeur, "suppression_projet");
186
			}
191
			}
187
		});
192
		});
188
	}
193
	}
189
	
194
	
190
	private void traiterReponse(JSONValue reponseValeur, String type) {
195
	private void traiterReponse(JSONValue reponseValeur, String type) {
191
		Information info = new Information(type);
196
		Information info = new Information(type);
192
		String idsNonSuppr = "";
197
		String idsNonSuppr = "";
193
		
198
		
194
		// Si la requête est un succès, réception d'une chaîne
199
		// Si la requête est un succès, réception d'une chaîne
195
		if (type.equals("suppression_projet") && reponseValeur.isArray() != null)	{
200
		if (type.equals("suppression_projet") && reponseValeur.isArray() != null)	{
196
			JSONArray tableauInfo = reponseValeur.isArray();
201
			JSONArray tableauInfo = reponseValeur.isArray();
197
			idsNonSuppr = tableauInfo.get(0).isString().stringValue();
202
			idsNonSuppr = tableauInfo.get(0).isString().stringValue();
198
		} else if (reponseValeur.isString() != null) {
203
		} else if (reponseValeur.isString() != null) {
199
			String idOuMessage = reponseValeur.isString().stringValue();
204
			String idOuMessage = reponseValeur.isString().stringValue();
200
			if (idOuMessage.matches("^[0-9]+$")) {
205
			if (idOuMessage.matches("^[0-9]+$")) {
201
				info.setDonnee(idOuMessage);
206
				info.setDonnee(idOuMessage);
202
			} else {
207
			} else {
203
				info.setDonnee("");
208
				info.setDonnee("");
204
				info.setMessage(idOuMessage);
209
				info.setMessage(idOuMessage);
205
			}
210
			}
206
		} else {
211
		} else {
207
			info.setDeboguage("La réponse n'est pas une chaine JSON.");
212
			info.setDeboguage("La réponse n'est pas une chaine JSON.");
208
		}
213
		}
209
		info.setDonnee(1, idsNonSuppr);
214
		info.setDonnee(1, idsNonSuppr);
210
		vueARafraichir.rafraichir(info);
215
		vueARafraichir.rafraichir(info);
211
	}
216
	}
212
}
217
}