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

Diff of /android/TrainInfoServiceGoogle/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 584 by torben, Fri Feb 5 13:57:39 2010 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;
30                    
31                    
32          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());
33                    
34            private boolean useTempSite;
35            
36            public TimetableFetcher(boolean tmpSite, int cacheTimeout) {
37                    useTempSite = tmpSite;
38                    
39                    cache = new TimeoutMap<String,List<TimetableBean>>(cacheTimeout);
40            }
41            
42                    
43          List<TimetableBean> cachedLookupTimetable(String trainID, String type) throws Exception {          List<TimetableBean> cachedLookupTimetable(String trainID, String type) throws Exception {
44                  String key = trainID+type;                  String key = trainID+type;
45                  List<TimetableBean> list = cache.get(key);                  List<TimetableBean> list = cache.get(key);
46                                    
47                  if (list == null) {                  if (list == null) {
                         logger.warning("Timetable: Cache miss " + trainID); //remove before production  
48                          list = lookupTimetable(trainID,type);                          list = lookupTimetable(trainID,type);
49                          cache.put(key, list);                          cache.put(key, list);
50                  } else {                  } else {
51                          logger.warning("Timetable: Cache hit " + trainID); //remove before production                          logger.info("Timetable: Cache hit " + trainID);
52                  }                  }
53                  return list;                  return list;
54          }          }
55            
56            List<TimetableBean> lookupTimetable(String trainID, String type) throws Exception {
57                    if (useTempSite == false ){
58                            return lookupTimetableRealSite(trainID, type);
59                    } else {
60                            return new ArrayList<TimetableBean>(); // no timetable data on temp site
61                    }
62            }
63    
64          List<TimetableBean> lookupTimetable(String trainID, String type) throws Exception {                      List<TimetableBean> lookupTimetableRealSite(String trainID, String type) throws Exception {            
65                  List<TimetableBean> timetableList = new ArrayList<TimetableBean>();                  List<TimetableBean> timetableList = new ArrayList<TimetableBean>();
66                                    
67                  String url = "http://www.bane.dk/visRute.asp?W=" + type + "&TogNr=" + trainID + "&artikelId=4276";                  String url = "http://www.bane.dk/visRute.asp?W=" + type + "&TogNr=" + trainID + "&artikelId=4276";
# Line 55  public class TimetableFetcher { Line 74  public class TimetableFetcher {
74              webClient.setCssEnabled(false);              webClient.setCssEnabled(false);
75                            
76                            
77              final HtmlPage page = webClient.getPage(url);              BanedkInvocation wrapper = new BanedkInvocation(webClient, url);
78                CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("banedk");
79                            
80                HtmlPage page = (HtmlPage) breaker.invoke(wrapper);
81                        
82                            
83              boolean currentStation = false;              boolean currentStation = false;
84              boolean currentStationSaved = false;              boolean currentStationSaved = false;

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

  ViewVC Help
Powered by ViewVC 1.1.20