Subversion Repositories eFlore/Applications.coel

Rev

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

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