/[projects]/android/TrainInfoService/src/dk/thoerup/traininfoservice/banedk/TimetableFetcher.java
ViewVC logotype

Diff of /android/TrainInfoService/src/dk/thoerup/traininfoservice/banedk/TimetableFetcher.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 387 by torben, Fri Oct 2 15:06:08 2009 UTC revision 468 by torben, Thu Oct 22 06:04:45 2009 UTC
# Line 5  import java.io.IOException; Line 5  import java.io.IOException;
5  import java.net.URL;  import java.net.URL;
6  import java.util.ArrayList;  import java.util.ArrayList;
7  import java.util.List;  import java.util.List;
8    import java.util.Map;
9  import java.util.logging.Logger;  import java.util.logging.Logger;
10    
11  import com.gargoylesoftware.htmlunit.Page;  import com.gargoylesoftware.htmlunit.Page;
# Line 14  import com.gargoylesoftware.htmlunit.htm Line 15  import com.gargoylesoftware.htmlunit.htm
15  import com.gargoylesoftware.htmlunit.html.HtmlElement;  import com.gargoylesoftware.htmlunit.html.HtmlElement;
16  import com.gargoylesoftware.htmlunit.html.HtmlPage;  import com.gargoylesoftware.htmlunit.html.HtmlPage;
17    
18    import dk.thoerup.circuitbreaker.CircuitBreaker;
19    import dk.thoerup.circuitbreaker.CircuitBreakerManager;
20    
21  public class TimetableFetcher {  public class TimetableFetcher {
22                    
23          class NullRefreshHandler implements RefreshHandler {          class NullRefreshHandler implements RefreshHandler {
# Line 22  public class TimetableFetcher { Line 26  public class TimetableFetcher {
26                                    
27          }          }
28                                    
29          TimeoutCache<String, List<TimetableBean>> cache = new TimeoutCache<String,List<TimetableBean>>(120 * 1000);          Map<String, List<TimetableBean>> cache = new TimeoutMap<String,List<TimetableBean>>(120 * 1000);
30                    
31                    
32          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());
# Line 33  public class TimetableFetcher { Line 37  public class TimetableFetcher {
37                  List<TimetableBean> list = cache.get(key);                  List<TimetableBean> list = cache.get(key);
38                                    
39                  if (list == null) {                  if (list == null) {
                         logger.warning("Timetable: Cache miss " + trainID); //remove before production  
40                          list = lookupTimetable(trainID,type);                          list = lookupTimetable(trainID,type);
41                          cache.put(key, list);                          cache.put(key, list);
42                  } else {                  } else {
43                          logger.warning("Timetable: Cache hit " + trainID); //remove before production                          logger.info("Timetable: Cache hit " + trainID);
44                  }                  }
45                  return list;                  return list;
46          }          }
# Line 55  public class TimetableFetcher { Line 58  public class TimetableFetcher {
58              webClient.setCssEnabled(false);              webClient.setCssEnabled(false);
59                            
60                            
61              final HtmlPage page = webClient.getPage(url);              BanedkInvocation wrapper = new BanedkInvocation(webClient, url);
62                CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("banedk");
63                            
64                HtmlPage page = (HtmlPage) breaker.invoke(wrapper);
65                        
66                            
67              boolean currentStation = false;              boolean currentStation = false;
68              boolean currentStationSaved = false;              boolean currentStationSaved = false;

Legend:
Removed from v.387  
changed lines
  Added in v.468

  ViewVC Help
Powered by ViewVC 1.1.20