Subversion Repositories eFlore/Applications.coel

Rev

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

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