Subversion Repositories eFlore/Applications.coel

Rev

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

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