/[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 992 by torben, Wed Jul 14 08:05:31 2010 UTC revision 1355 by torben, Wed Apr 20 19:01:33 2011 UTC
# Line 4  package dk.thoerup.traininfoservice.bane Line 4  package dk.thoerup.traininfoservice.bane
4    
5  import java.net.URL;  import java.net.URL;
6  import java.sql.SQLException;  import java.sql.SQLException;
 import java.util.ArrayList;  
 import java.util.List;  
7  import java.util.Map;  import java.util.Map;
8  import java.util.logging.Level;  import java.util.logging.Level;
9  import java.util.logging.Logger;  import java.util.logging.Logger;
# Line 14  import org.jsoup.nodes.Document; Line 12  import org.jsoup.nodes.Document;
12  import org.jsoup.nodes.Element;  import org.jsoup.nodes.Element;
13  import org.jsoup.select.Elements;  import org.jsoup.select.Elements;
14    
15    import dk.thoerup.android.traininfo.common.TimetableBean;
16    import dk.thoerup.android.traininfo.common.TimetableEntry;
17  import dk.thoerup.circuitbreaker.CircuitBreaker;  import dk.thoerup.circuitbreaker.CircuitBreaker;
18  import dk.thoerup.circuitbreaker.CircuitBreakerManager;  import dk.thoerup.circuitbreaker.CircuitBreakerManager;
19  import dk.thoerup.traininfoservice.StationDAO;  import dk.thoerup.genericjavautils.TimeoutMap;
20  import dk.thoerup.traininfoservice.Statistics;  import dk.thoerup.traininfoservice.Statistics;
21    import dk.thoerup.traininfoservice.TraininfoSettings;
22    import dk.thoerup.traininfoservice.db.StationDAO;
23    
24  public class TimetableFetcher {  public class TimetableFetcher {
25    
26                                    
27          Map<String, List<TimetableBean>> cache;          Map<String, TimetableBean> cache;
28          Map<String, Integer> stationCache;          Map<String, Integer> stationCache;
29    
30          StationDAO stationDao = new StationDAO();          StationDAO stationDao = new StationDAO();
31                    
32                    
33          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());          Logger logger = Logger.getLogger(TimetableFetcher.class.getName());
34    
35            TraininfoSettings settings;    
36                    
37          private boolean useTempSite;          public TimetableFetcher(TraininfoSettings settings) {
38                            this.settings = settings;
         public TimetableFetcher(boolean tmpSite, int cacheTimeout) {  
                 useTempSite = tmpSite;  
39                                    
40                  cache = new TimeoutMap<String,List<TimetableBean>>(cacheTimeout);                  cache = new TimeoutMap<String,TimetableBean>( settings.getCacheTimeout() );
41                  stationCache = new TimeoutMap<String,Integer>( 3*60*60*1000 );                  stationCache = new TimeoutMap<String,Integer>( 3*60*60*1000 );
42          }          }
43                    
44                    
45          List<TimetableBean> cachedLookupTimetable(String trainID, String type) throws Exception {          TimetableBean cachedLookupTimetable(String trainID, String type) throws Exception {
46                  String key = trainID+type;                  String key = trainID+type;
47                  List<TimetableBean> list = cache.get(key);                  TimetableBean list = cache.get(key);
48                                    
49                  if (list == null) {                  if (list == null) {
50                          list = lookupTimetable(trainID,type);                          list = lookupTimetable(trainID,type);
# Line 54  public class TimetableFetcher { Line 56  public class TimetableFetcher {
56                  return list;                  return list;
57          }          }
58                    
59          List<TimetableBean> lookupTimetable(String trainID, String type) throws Exception {          TimetableBean lookupTimetable(String trainID, String type) throws Exception {
60                  if (useTempSite == false ){                  if (settings.getUseAzureSite() == true ){
61                          return lookupTimetableRealSite(trainID, type);                          return lookupTimetableAzureSite(trainID, type);
62                            
63                  } else {                  } else {
64                          return new ArrayList<TimetableBean>(); // no timetable data on temp site                          return lookupTimetableMobileSite(trainID, type);
65                  }                  }
66          }          }
67                    
# Line 78  public class TimetableFetcher { Line 81  public class TimetableFetcher {
81                  return id;                  return id;
82          }          }
83    
84          List<TimetableBean> lookupTimetableRealSite(String trainID, String type) throws Exception {                      TimetableBean lookupTimetableAzureSite(String trainID, String type) throws Exception {          
85                  List<TimetableBean> timetableList = new ArrayList<TimetableBean>();                  TimetableBean timetableBean = new TimetableBean();
86                                    
                 //String url = "http://www.bane.dk/visRute.asp?W=" + type + "&TogNr=" + trainID + "&artikelId=4276";  
                 String url = "http://trafikinfo.bane.dk/TrafikInformation/Ruteplan/" + trainID;                  
87    
88                    String url = "http://trafikinfo.bane.dk/TrafikInformation/Ruteplan/" + trainID;                
89                    logger.fine("URL:" + url);
90                            
91              JsoupInvocation wrapper = new JsoupInvocation( new URL(url) , 2500);              JsoupInvocation wrapper = new JsoupInvocation( new URL(url) , settings.getReplyTimeout() );
92              CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("banedk");              CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("banedk");
93                            
94              Document doc = (Document) breaker.invoke(wrapper);              Document doc = (Document) breaker.invoke(wrapper);
# Line 114  public class TimetableFetcher { Line 117  public class TimetableFetcher {
117                                  continue;                                  continue;
118                          }                          }
119                                                    
120                          TimetableBean bean = new TimetableBean();                          TimetableEntry entry = new TimetableEntry();
121                                                    
122                          String station = fields.get(0).text() ;                          String station = fields.get(0).text() ;
123                          if (station.equals("København"))                          if (station.equals("København"))
124                                  station = "København H"; //correct inconsistency in naming                                  station = "København H"; //correct inconsistency in naming
125                                                    
126                          bean.setStation( station );                          entry.setStation( station );
127                          bean.setArrival( fields.get(1).text() );                          entry.setArrival( fields.get(1).text() );
128                          bean.setDeparture( fields.get(2).text() );                          entry.setDeparture( fields.get(2).text() );
129                                                    
130                          boolean cancelled = fields.get(3).text().equalsIgnoreCase("aflyst");                          boolean cancelled = fields.get(3).text().equalsIgnoreCase("aflyst");
131                          bean.setCancelled(cancelled);                          entry.setCancelled(cancelled);
132                                                    
133                          if (currentStation == true && currentStationSaved == false ) {                          if (currentStation == true && currentStationSaved == false ) {
134                                  bean.setCurrent(currentStation);                                  entry.setCurrent(currentStation);
135                                  currentStationSaved = true;                                  currentStationSaved = true;
136                          }                          }
137                                                    
138                          bean.setStationId( getStationId( station ));                          entry.setStationId( getStationId( station ));
139                                                    
140                          timetableList.add(bean);                          timetableBean.entries.add(entry);
141                  }                  }
142                                    
143                  //TODO: There is an off-by-one error in this cancelled parser thingie                  //TODO: There is an off-by-one error in this cancelled parser thingie
144                  final String cancelledString = "Aflyst";                  final String cancelledString = "Aflyst";
145                  for (int i=0;i<timetableList.size(); i++) { //handle cancelled labels                  for (int i=0;i<timetableBean.entries.size(); i++) { //handle cancelled labels
146                          final int lastIdx = (timetableList.size() - 1);                          final int lastIdx = (timetableBean.entries.size() - 1);
147                                                    
148                          TimetableBean current = timetableList.get(i);                          TimetableEntry current = timetableBean.entries.get(i);
149                          if (current.isCancelled()) {                          if (current.isCancelled()) {
150                                  if (i == 0) {                                  if (i == 0) {
151                                          current.setDeparture(cancelledString);                                          current.setDeparture(cancelledString);
152                                  } else if (i == lastIdx) {                                  } else if (i == lastIdx) {
153                                          current.setArrival(cancelledString);                                          current.setArrival(cancelledString);
154                                  } else if (i>0 && i<lastIdx) {                                  } else if (i>0 && i<lastIdx) {
155                                          TimetableBean next = timetableList.get(i+1);                                          TimetableEntry next = timetableBean.entries.get(i+1);
156                                          TimetableBean prev = timetableList.get(i-1);                                          TimetableEntry prev = timetableBean.entries.get(i-1);
157                                                                                    
158                                          if (next.isCancelled())                                          if (next.isCancelled())
159                                                  current.setDeparture(cancelledString);                                                  current.setDeparture(cancelledString);
# Line 165  public class TimetableFetcher { Line 168  public class TimetableFetcher {
168              }              }
169                            
170                                    
171                  return timetableList;                  return timetableBean;
172          }          }
173    
174            TimetableBean lookupTimetableMobileSite(String trainID, String type) throws Exception {
175                    return new TimetableBean(); //dummy skeleton method
176            }
177            
178            @Deprecated
179            TimetableBean lookupTimetableWwwSite(String trainID, String type) throws Exception {            
180                    TimetableBean timetableBean = new TimetableBean();
181                    
182                    String url = "http://www.bane.dk/visRute.asp?W=" + type + "&TogNr=" + trainID + "&artikelId=4276";
183                    logger.fine("URL:" + url);
184    
185                
186                JsoupInvocation wrapper = new JsoupInvocation( new URL(url) , settings.getReplyTimeout() );
187                CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("banedk");
188                
189                Document doc = (Document) breaker.invoke(wrapper);
190                        
191                
192                boolean currentStation = false;
193                boolean currentStationSaved = false;
194                
195                Elements tables = doc.getElementsByClass("Rute");
196                
197                if (tables.size() == 1) {
198                    Element timetable = tables.get(0);
199                    Elements rows = timetable.getElementsByTag("tr");
200                    
201                    for (int i=0; i<rows.size(); i++) {
202                            if (i==0) //First row is column headers
203                                    continue;
204                            
205                            
206                            Element row = rows.get(i);
207                            Elements fields = row.getElementsByTag("td");
208    
209                            
210                            if (currentStationSaved == false && fields.get(0).attr("class").equalsIgnoreCase("Tidsstreg")) {
211                                    currentStation = true;
212                                    continue;
213                            }
214                            
215                            TimetableEntry entry = new TimetableEntry();
216                            
217                            String station = DepartureFetcher.cleanText( fields.get(0).text() ) ;
218                            if (station.equals("København"))
219                                    station = "København H"; //correct inconsistency in naming
220                            
221                            String arrival = DepartureFetcher.cleanText( fields.get(1).text() );
222                            String departure = DepartureFetcher.cleanText( fields.get(2).text() );
223                            
224                            entry.setStation( station );
225                            entry.setArrival( arrival );
226                            entry.setDeparture( departure );
227                    
228                            
229                            if (currentStation == true && currentStationSaved == false ) {
230                                    entry.setCurrent(currentStation);
231                                    currentStationSaved = true;
232                            }
233                            
234                            entry.setStationId( getStationId( station ));
235                            
236                            timetableBean.entries.add(entry);
237                    }              
238                    
239                } else {
240                    logger.warning("No time table found, trainID=" + trainID + " type=" + type);
241                }
242                
243                    
244                    return timetableBean;
245            }      
246                    
247  }  }

Legend:
Removed from v.992  
changed lines
  Added in v.1355

  ViewVC Help
Powered by ViewVC 1.1.20