Rev 457 | Rev 485 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
90 | jmachado | 1 | package pt.estgp.estgweb.services.common; |
2 | |||
163 | jmachado | 3 | import jomm.ir.lucene.LuceneUtils; |
4 | import org.apache.log4j.Logger; |
||
90 | jmachado | 5 | import pt.estgp.estgweb.Globals; |
163 | jmachado | 6 | import pt.estgp.estgweb.domain.DomainObject; |
7 | import pt.estgp.estgweb.domain.UserSession; |
||
90 | jmachado | 8 | import pt.estgp.estgweb.services.common.impl.CommonSearchResults; |
92 | jmachado | 9 | import pt.estgp.estgweb.services.common.impl.DefaultResult; |
163 | jmachado | 10 | import pt.estgp.estgweb.services.common.impl.DefaultSearchResults; |
156 | jmachado | 11 | import pt.estgp.estgweb.services.common.impl.DefaultToDoCat; |
163 | jmachado | 12 | import pt.estgp.estgweb.web.UserSessionProxy; |
13 | import pt.estgp.estgweb.web.exceptions.NotAuthorizedException; |
||
14 | import pt.estgp.estgweb.web.utils.TestHttpServletRequest; |
||
15 | import pt.utl.ist.berserk.logic.filterManager.exceptions.FilterRetrieveException; |
||
90 | jmachado | 16 | |
17 | import java.util.ArrayList; |
||
163 | jmachado | 18 | import java.util.List; |
90 | jmachado | 19 | |
20 | /** |
||
21 | * @author Jorge Machado |
||
22 | * @date 24/Abr/2008 |
||
23 | * @time 14:55:22 |
||
24 | * @see pt.estgp.estgweb.services.common |
||
25 | */ |
||
156 | jmachado | 26 | public class CommonServicesManager |
27 | { |
||
90 | jmachado | 28 | |
92 | jmachado | 29 | private static final int SEARCH_FRAGMENT_SIZE = Globals.SEARCH_BEST_FRAGMENTS_MAX_FRAGMENT_SIZE; |
30 | private static final int SEARCH_MAX_FRAGMENTS = Globals.SEARCH_BEST_FRAGMENTS_MAX_FRAGMENTS; |
||
31 | private static final int SEARCH_MAX_RESULTS = Globals.SEARCH_MAX_RESULTS; |
||
90 | jmachado | 32 | |
33 | private static final 1.5.0/docs/api/java/util/logging/Logger.html">Logger logger = 1.5.0/docs/api/java/util/logging/Logger.html">Logger.getLogger(CommonServicesManager.class); |
||
34 | |||
35 | private static CommonServicesManager ourInstance = new CommonServicesManager(); |
||
36 | |||
156 | jmachado | 37 | public static CommonServicesManager getInstance() |
38 | { |
||
90 | jmachado | 39 | return ourInstance; |
40 | } |
||
41 | |||
156 | jmachado | 42 | private CommonServicesManager() |
43 | { |
||
90 | jmachado | 44 | } |
45 | |||
46 | /** |
||
163 | jmachado | 47 | * @param userSession asking |
90 | jmachado | 48 | * @param query to execute |
49 | * @param searchType see SearchTypeEnum |
||
50 | * @return Cluster of Results for each Module with total module results, only return modules with results |
||
51 | * @throws Throwable on notAuthorized or internal error |
||
52 | */ |
||
163 | jmachado | 53 | public ICommonSearchResults search(UserSession userSession, 1.5.0/docs/api/java/lang/String.html">String query, SearchTypeEnum searchType) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 54 | { |
165 | jmachado | 55 | return search(userSession,query,searchType,null); |
56 | } |
||
90 | jmachado | 57 | |
165 | jmachado | 58 | /** |
59 | * @param userSession asking |
||
60 | * @param query to execute |
||
61 | * @param searchType see SearchTypeEnum |
||
62 | * @param from interface from |
||
63 | * @return Cluster of Results for each Module with total module results, only return modules with results |
||
64 | * @throws Throwable on notAuthorized or internal error |
||
65 | */ |
||
66 | public ICommonSearchResults search(UserSession userSession, 1.5.0/docs/api/java/lang/String.html">String query, SearchTypeEnum searchType, 1.5.0/docs/api/java/lang/String.html">String from) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
||
67 | { |
||
68 | |||
156 | jmachado | 69 | if (searchType == null) |
92 | jmachado | 70 | searchType = SearchTypeEnum.AllWords; |
90 | jmachado | 71 | CommonSearchResults commonSearchResults = new CommonSearchResults(); |
481 | jmachado | 72 | if(query != null && query.trim().length() > 0) |
73 | { |
||
90 | jmachado | 74 | |
481 | jmachado | 75 | |
76 | List<ISearchResults> results = new ArrayList<ISearchResults>(); |
||
77 | |||
78 | for (ModuleEnum module : ModuleEnum.values()) |
||
156 | jmachado | 79 | { |
481 | jmachado | 80 | if (module.getModuleCommonServices() != null) |
81 | { |
||
82 | List<ISearchResults> iSearchResultsList = search(userSession, query, searchType, module,null, 0, from); |
||
83 | if(iSearchResultsList != null && iSearchResultsList.size() > 0) |
||
84 | for(ISearchResults iSearchResults: iSearchResultsList) |
||
457 | jmachado | 85 | { |
481 | jmachado | 86 | if (iSearchResults != null && iSearchResults.getTotalResults() > 0) |
87 | { |
||
88 | results.add(iSearchResults); |
||
89 | commonSearchResults.addMoreResults(iSearchResults.getTotalResults()); |
||
90 | } |
||
457 | jmachado | 91 | } |
481 | jmachado | 92 | } |
90 | jmachado | 93 | } |
481 | jmachado | 94 | commonSearchResults.setResults(results); |
90 | jmachado | 95 | } |
481 | jmachado | 96 | else |
97 | { |
||
98 | commonSearchResults.setResults(new ArrayList<ISearchResults>()); |
||
99 | } |
||
104 | jmachado | 100 | commonSearchResults.setQuery(query); |
101 | commonSearchResults.setSearchType(searchType.getMessageKey()); |
||
90 | jmachado | 102 | return commonSearchResults; |
103 | } |
||
104 | |||
105 | |||
106 | /** |
||
107 | * The service called inside implements method |
||
108 | * <p/> |
||
109 | * public ISearchResults search(String search, SearchTypeEnum searchType, int page, int maxResults, UserSession userSession); |
||
110 | * |
||
163 | jmachado | 111 | * @param userSession asking |
90 | jmachado | 112 | * @param query to execute |
113 | * @param searchType see SearchTypeEnum |
||
114 | * @param moduleKey to search in |
||
115 | * @param page of start result |
||
165 | jmachado | 116 | * @param from interface from |
90 | jmachado | 117 | * @return searchResults |
118 | * @throws Throwable on not authorized and internal error |
||
119 | */ |
||
457 | jmachado | 120 | public List<ISearchResults> search(UserSession userSession, 1.5.0/docs/api/java/lang/String.html">String query, SearchTypeEnum searchType, ModuleEnum moduleKey,1.5.0/docs/api/java/lang/String.html">String moduleInternalKey, int page, 1.5.0/docs/api/java/lang/String.html">String from) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 121 | { |
122 | try |
||
123 | { |
||
163 | jmachado | 124 | // sm = ServiceManager.getInstance(); |
125 | // String[] names = new String[]{}; |
||
126 | // Object[] args = new Object[]{query, searchType, page, SEARCH_MAX_RESULTS}; |
||
92 | jmachado | 127 | |
457 | jmachado | 128 | List<ISearchResults> searchResultsList = moduleKey.getModuleCommonServices().searchList(moduleInternalKey, from, query, searchType, page, SEARCH_MAX_RESULTS, userSession); //(DefaultSearchResults) sm.execute(requester, moduleKey.getSearchService(), "search", args, names); |
129 | if(searchResultsList == null || searchResultsList.size() == 0) |
||
130 | return null; |
||
131 | for(ISearchResults iSearchResults: searchResultsList) |
||
92 | jmachado | 132 | { |
457 | jmachado | 133 | DefaultSearchResults searchResults = (DefaultSearchResults) iSearchResults; |
134 | |||
164 | jmachado | 135 | searchResults.setPage(page); |
136 | searchResults.setMaxResultsPage(SEARCH_MAX_RESULTS); |
||
137 | searchResults.setQuery(query.replace("'", " ")); |
||
138 | searchResults.setSearchType(searchType.getMessageKey()); |
||
139 | if (searchResults.getTotalResults() > 0) |
||
92 | jmachado | 140 | { |
164 | jmachado | 141 | for (IResult result : searchResults.getResults()) |
92 | jmachado | 142 | { |
164 | jmachado | 143 | DefaultResult defaultResult = (DefaultResult) result; |
455 | jmachado | 144 | if(defaultResult.getBestFragments() == null || defaultResult.getBestFragments().trim().length() == 0) |
145 | defaultResult.setBestFragments(LuceneUtils.doStandardHighlights(defaultResult.getText(), query, SEARCH_FRAGMENT_SIZE, SEARCH_MAX_FRAGMENTS)); |
||
164 | jmachado | 146 | if (!defaultResult.isTitleKey()) |
147 | { |
||
148 | 1.5.0/docs/api/java/lang/String.html">String title = defaultResult.getTitle(); |
||
149 | defaultResult.setTitle(LuceneUtils.highlight(defaultResult.getTitle(), query)); |
||
150 | if (defaultResult.getTitle() == null || defaultResult.getTitle().length() == 0) |
||
151 | defaultResult.setTitle(title); |
||
152 | } |
||
153 | if (!defaultResult.isSubTitleKey()) |
||
154 | { |
||
155 | 1.5.0/docs/api/java/lang/String.html">String subTitle = defaultResult.getSubTitle(); |
||
156 | defaultResult.setSubTitle(LuceneUtils.highlight(defaultResult.getSubTitle(), query)); |
||
157 | if (defaultResult.getSubTitle() == null || defaultResult.getSubTitle().length() == 0) |
||
158 | defaultResult.setSubTitle(subTitle); |
||
159 | } |
||
455 | jmachado | 160 | if(defaultResult.getText() != null && defaultResult.getText().trim().length() > 0) |
161 | { |
||
162 | 1.5.0/docs/api/java/lang/String.html">String text = defaultResult.getText(); |
||
163 | |||
164 | defaultResult.setText(LuceneUtils.highlight(defaultResult.getText(), query)); |
||
165 | if (defaultResult.getText() == null || defaultResult.getText().length() == 0) |
||
166 | defaultResult.setText(text); |
||
167 | } |
||
92 | jmachado | 168 | } |
169 | } |
||
165 | jmachado | 170 | } |
457 | jmachado | 171 | return searchResultsList; |
90 | jmachado | 172 | } |
156 | jmachado | 173 | catch (FilterRetrieveException e) |
174 | { |
||
90 | jmachado | 175 | logger.error(e, e); |
176 | throw new NotAuthorizedException(e.toString()); |
||
177 | } |
||
156 | jmachado | 178 | catch (1.5.0/docs/api/java/lang/Throwable.html">Throwable e) |
179 | { |
||
373 | jmachado | 180 | logger.error(moduleKey.getMessageKey() + " - query:" + query + ": " + e, e); |
90 | jmachado | 181 | throw e; |
182 | } |
||
183 | } |
||
184 | |||
163 | jmachado | 185 | public List<IToDoCat> getToDosCats(UserSession userSession) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 186 | { |
90 | jmachado | 187 | List<IToDoCat> toDoCats = new ArrayList<IToDoCat>(); |
188 | |||
156 | jmachado | 189 | for (ModuleEnum module : ModuleEnum.values()) |
190 | { |
||
163 | jmachado | 191 | if (module.getModuleCommonServices() != null) |
156 | jmachado | 192 | { |
163 | jmachado | 193 | IToDoCat toDoCat = getToDoCats(userSession, module); |
156 | jmachado | 194 | if (toDoCat != null) |
195 | { |
||
90 | jmachado | 196 | toDoCats.add(toDoCat); |
197 | } |
||
198 | } |
||
199 | } |
||
200 | return toDoCats; |
||
201 | } |
||
202 | |||
163 | jmachado | 203 | public List<IToDoCat> getAllToDosCats(UserSession userSession) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 204 | { |
205 | List<IToDoCat> toDoCats = new ArrayList<IToDoCat>(); |
||
206 | for (ModuleEnum module : ModuleEnum.values()) |
||
207 | { |
||
163 | jmachado | 208 | if (module.getModuleCommonServices() != null) |
156 | jmachado | 209 | { |
163 | jmachado | 210 | IToDoCat toDoCat = getAllToDoCats(userSession, module); |
156 | jmachado | 211 | if (toDoCat != null && toDoCat.getTotalToDo() > 0) |
212 | { |
||
213 | toDoCats.add(toDoCat); |
||
214 | } |
||
215 | } |
||
216 | } |
||
217 | return toDoCats; |
||
218 | } |
||
219 | |||
163 | jmachado | 220 | public IToDoCat getToDoCats(UserSession userSession, 1.5.0/docs/api/java/lang/String.html">String moduleKey) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 221 | { |
163 | jmachado | 222 | return getToDoCats(userSession, ModuleEnum.parse(moduleKey)); |
90 | jmachado | 223 | } |
224 | |||
225 | |||
226 | /** |
||
163 | jmachado | 227 | * @param userSession asking |
228 | * @param module to search |
||
90 | jmachado | 229 | * @return Number of ToDos in given module |
230 | * @throws Throwable on Error or NotAuthorized Exception |
||
231 | */ |
||
163 | jmachado | 232 | public IToDoCat getToDoCats(UserSession userSession, ModuleEnum module) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 233 | { |
163 | jmachado | 234 | // IServiceManager sm; |
156 | jmachado | 235 | try |
236 | { |
||
163 | jmachado | 237 | return module.getModuleCommonServices().getToDo(userSession); |
238 | // sm = ServiceManager.getInstance(); |
||
239 | // String[] names = new String[]{}; |
||
240 | // Object[] args = new Object[]{}; |
||
241 | // return (IToDoCat) sm.execute(requester, module.getGetToDoService(), "getToDo", args, names); |
||
90 | jmachado | 242 | } |
156 | jmachado | 243 | catch (1.5.0/docs/api/java/lang/Throwable.html">Throwable e) |
244 | { |
||
90 | jmachado | 245 | logger.error(e, e); |
246 | throw e; |
||
247 | } |
||
248 | } |
||
249 | |||
156 | jmachado | 250 | /** |
163 | jmachado | 251 | * @param userSession asking |
156 | jmachado | 252 | * @param module to search |
253 | * @return Number of ToDos in given module |
||
254 | * @throws Throwable on Error or NotAuthorized Exception |
||
255 | */ |
||
163 | jmachado | 256 | public IToDoCat getAllToDoCats(UserSession userSession, ModuleEnum module) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
156 | jmachado | 257 | { |
163 | jmachado | 258 | // IServiceManager sm; |
156 | jmachado | 259 | try |
260 | { |
||
163 | jmachado | 261 | // sm = ServiceManager.getInstance(); |
262 | // String[] names = new String[]{}; |
||
263 | // Object[] args = new Object[]{}; |
||
264 | // List<IToDo> todos = (List<IToDo>) sm.execute(requester, module.getAllToDosService(), "getAllToDos", args, names); |
||
265 | List<IToDo> todos = module.getModuleCommonServices().getAllToDos(userSession); |
||
156 | jmachado | 266 | DefaultToDoCat toDoCat = new DefaultToDoCat(); |
267 | toDoCat.setAllToDos(todos); |
||
268 | toDoCat.setDescription(module.getMessageKey()); |
||
269 | return toDoCat; |
||
270 | } |
||
271 | catch (1.5.0/docs/api/java/lang/Throwable.html">Throwable e) |
||
272 | { |
||
273 | logger.error(e, e); |
||
274 | throw e; |
||
275 | } |
||
276 | } |
||
90 | jmachado | 277 | |
163 | jmachado | 278 | /** |
279 | * Advise modules for new object creation |
||
280 | * @param domainObject created |
||
281 | */ |
||
164 | jmachado | 282 | public void adviseNew(DomainObject domainObject) |
163 | jmachado | 283 | { |
284 | for (ModuleEnum module : ModuleEnum.values()) |
||
285 | { |
||
286 | module.getModuleCommonServices().adviseNew(domainObject); |
||
287 | } |
||
288 | } |
||
156 | jmachado | 289 | |
163 | jmachado | 290 | /** |
164 | jmachado | 291 | * Advise modules for new object creation |
292 | * @param domainObject created |
||
293 | */ |
||
294 | public void adviseUpdate(DomainObject domainObject) |
||
295 | { |
||
296 | for (ModuleEnum module : ModuleEnum.values()) |
||
163 | jmachado | 297 | { |
164 | jmachado | 298 | module.getModuleCommonServices().adviseUpdate(domainObject); |
163 | jmachado | 299 | } |
164 | jmachado | 300 | } |
163 | jmachado | 301 | |
302 | |||
303 | |||
90 | jmachado | 304 | public static void main(1.5.0/docs/api/java/lang/String.html">String[] args) throws 1.5.0/docs/api/java/lang/Throwable.html">Throwable |
305 | { |
||
163 | jmachado | 306 | ICommonSearchResults commonSearchResults = new CommonServicesManager().search(UserSessionProxy.loadUserSession(new TestHttpServletRequest("2093FFF41F61E375D2CB4CBEDE4400E9"),null), "teste", SearchTypeEnum.AllWords); |
156 | jmachado | 307 | for (ISearchResults searchResults : commonSearchResults.getSearchResults()) |
90 | jmachado | 308 | { |
309 | 1.5.0/docs/api/java/lang/System.html">System.out.println("-----------------------------------------------------"); |
||
310 | 1.5.0/docs/api/java/lang/System.html">System.out.println("Module" + searchResults.getModule().getMessageKey()); |
||
156 | jmachado | 311 | for (IResult result : searchResults.getResults()) |
90 | jmachado | 312 | { |
313 | 1.5.0/docs/api/java/lang/System.html">System.out.println(""); |
||
156 | jmachado | 314 | 1.5.0/docs/api/java/lang/System.html">System.out.println("\ttitle:" + result.getTitle()); |
315 | 1.5.0/docs/api/java/lang/System.html">System.out.println("\tsubTitle:" + result.getSubTitle()); |
||
316 | 1.5.0/docs/api/java/lang/System.html">System.out.println("\ttext:" + result.getText()); |
||
90 | jmachado | 317 | 1.5.0/docs/api/java/lang/System.html">System.out.println("\turl:" + result.getUrl()); |
318 | 1.5.0/docs/api/java/lang/System.html">System.out.println("\tbestFragments:" + result.getBestFragments()); |
||
92 | jmachado | 319 | |
90 | jmachado | 320 | } |
156 | jmachado | 321 | // System.out.println("NEXT PAGE TEST>>>>>>>>>>>>>>>>>>>"); |
322 | // ISearchResults searchResults2 = new CommonServicesManager().search("18D0D23A7C07FF478CE8DAFEBA58D37A","teste",SearchTypeEnum.AllWords,searchResults.getModule(),1); |
||
323 | // for(IResult result2: searchResults2.getResults()) |
||
324 | // { |
||
325 | // System.out.println(""); |
||
326 | // System.out.println("\ttitle:" +result2.getTitle()); |
||
327 | // System.out.println("\tsubTitle:" +result2.getSubTitle()); |
||
328 | // System.out.println("\ttext:" +result2.getText()); |
||
329 | // System.out.println("\turl:" + result2.getUrl()); |
||
330 | // System.out.println("\tbestFragments:" + result2.getBestFragments()); |
||
331 | // } |
||
92 | jmachado | 332 | |
90 | jmachado | 333 | } |
163 | jmachado | 334 | CommonServicesManager.getInstance().getAllToDosCats(UserSessionProxy.loadUserSession(new TestHttpServletRequest("2093FFF41F61E375D2CB4CBEDE4400E9"),null)); |
335 | 1.5.0/docs/api/java/lang/System.html">System.out.println(CommonServicesManager.getInstance().getAllToDosCats(UserSessionProxy.loadUserSession(new TestHttpServletRequest("2093FFF41F61E375D2CB4CBEDE4400E9"),null))); |
||
90 | jmachado | 336 | } |
337 | |||
338 | } |