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

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

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

revision 468 by torben, Thu Oct 22 06:04:45 2009 UTC revision 716 by torben, Mon May 10 06:53:20 2010 UTC
# Line 1  Line 1 
1  package dk.thoerup.traininfoservice.banedk;  package dk.thoerup.traininfoservice.banedk;
2    
3  import java.io.IOException;  import java.io.IOException;
 import java.sql.Connection;  
 import java.sql.ResultSet;  
 import java.sql.Statement;  
4  import java.util.List;  import java.util.List;
5  import java.util.logging.Level;  import java.util.logging.Level;
6  import java.util.logging.Logger;  import java.util.logging.Logger;
# Line 25  import org.w3c.dom.Document; Line 22  import org.w3c.dom.Document;
22  import org.w3c.dom.Element;  import org.w3c.dom.Element;
23    
24  import dk.thoerup.circuitbreaker.CircuitBreakerException;  import dk.thoerup.circuitbreaker.CircuitBreakerException;
25  import dk.thoerup.traininfoservice.DBConnection;  import dk.thoerup.traininfoservice.StationDAO;
26    import dk.thoerup.traininfoservice.Statistics;
27    
28  /**  /**
29   * Servlet implementation class DepartureServlet   * Servlet implementation class DepartureServlet
# Line 35  public class DepartureServlet extends Ht Line 33  public class DepartureServlet extends Ht
33                    
34          Logger logger = Logger.getLogger( DepartureServlet.class.getName() );          Logger logger = Logger.getLogger( DepartureServlet.class.getName() );
35    
36          DepartureFetcher fetcher = new DepartureFetcher();          DepartureFetcher fetcher;
37      TransformerFactory transformerFactory = TransformerFactory.newInstance();      TransformerFactory transformerFactory = TransformerFactory.newInstance();
38          DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();          DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
39                    
40    
41          @Override          @Override
42          protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {          public void init() throws ServletException {
43                    super.init();
44    
45                    boolean useTempSite =  Boolean.parseBoolean( getServletContext().getInitParameter("usetempsite") );
46                    int cacheTimeout =  Integer.parseInt( getServletContext().getInitParameter("cache_timeout") );
47                    logger.info( "DepartureServlet, use temp site=" + useTempSite + ", cache=" + cacheTimeout);
48                    fetcher = new DepartureFetcher(useTempSite, cacheTimeout);
49            }
50    
51            @Override
52            protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {          
53                  if (req.getParameter("station") == null) {                  if (req.getParameter("station") == null) {
54                          resp.sendError(400, "not enough parameters");                          resp.sendError(400, "not enough parameters");
55                          return;                          return;
56                  }                  }
57                    Statistics.getInstance().incrementDepartureLookups();
58                                    
59                  int station = Integer.parseInt( req.getParameter("station") );                  int station = Integer.parseInt( req.getParameter("station") );
60                  String format = req.getParameter("format");                  String format = req.getParameter("format");
61    
62                  List<DepartureBean> beans;                  List<DepartureBean> beans;
63    
64                  String stationName = getStationName(station);                  String stationName = StationDAO.getStationName(station);
65    
66                  try {                  try {
67                          beans = fetcher.cachedLookupDepartures(station);                          beans = fetcher.cachedLookupDepartures(station);
68                  } catch (java.io.IOException ioe) {                  } catch (java.io.IOException ioe) {
69                          logger.warning("Read failed, station="+station + ". " + ioe.getMessage() );                          logger.warning("Read failed, station="+station + ". " + ioe.getMessage() );
70                            Statistics.getInstance().incrementDepartureErrors();
71                          resp.sendError(500);                          resp.sendError(500);
72                          return;                          return;
73                  } catch (CircuitBreakerException cbe) {                  } catch (CircuitBreakerException cbe) {
74                          logger.warning("Circuitbreaker - failing fast");                          logger.warning("Circuitbreaker - failing fast");
75                            Statistics.getInstance().incrementDepartureErrors();
76                          resp.sendError(500);                          resp.sendError(500);
77                          return;                          return;
78                  } catch (Exception e) {                                  } catch (Exception e) {                
79                          logger.log(Level.WARNING, "Unknown exception, station=" +station, e);                          logger.log(Level.WARNING, "Unknown exception, station=" +station, e);
80                            Statistics.getInstance().incrementDepartureErrors();
81                          resp.sendError(500);                          resp.sendError(500);
82                          return;                          return;
83                  }                  }
# Line 77  public class DepartureServlet extends Ht Line 89  public class DepartureServlet extends Ht
89                          resp.setContentType("text/xml");                          resp.setContentType("text/xml");
90                          resp.getWriter().print( formatXml(beans, stationName) );                          resp.getWriter().print( formatXml(beans, stationName) );
91                  } else if (format.equalsIgnoreCase("html")) {                  } else if (format.equalsIgnoreCase("html")) {
92                            
93                            String advStr = req.getParameter("advanced");
94                            boolean advanced = advStr != null ? Boolean.parseBoolean(advStr) : false;
95                            
96                            req.setAttribute("advanced", advanced);
97                          req.setAttribute("stationname", stationName );                          req.setAttribute("stationname", stationName );
98                          req.setAttribute("departurebeans", beans);                          req.setAttribute("departurebeans", beans);
99                          req.setAttribute("stationID", station );                          req.setAttribute("stationID", station );
# Line 132  public class DepartureServlet extends Ht Line 149  public class DepartureServlet extends Ht
149                          note.setTextContent( departure.getNote() );                          note.setTextContent( departure.getNote() );
150                          train.appendChild(note);                          train.appendChild(note);
151                                                    
152                            Element type = doc.createElement("type");
153                            type.setTextContent( departure.getType() );
154                            train.appendChild(type);
155                            
156                          root.appendChild(train);                          root.appendChild(train);
157                  }                  }
158                                    
# Line 158  public class DepartureServlet extends Ht Line 179  public class DepartureServlet extends Ht
179                  return xml;                  return xml;
180          }          }
181    
         protected String getStationName(int stationID) {  
                 String station = "";  
   
                 Connection conn = null;  
                 try {  
                         conn = DBConnection.getConnection();  
                         Statement stmt = conn.createStatement();  
                         ResultSet rs = stmt.executeQuery("SELECT name FROM trainstations WHERE id=" + stationID);  
                         if (rs.next()) {  
                                 station = rs.getString(1);  
                         }  
   
                 } catch (Exception e) {  
                 } finally {  
                         try {  
                                 if (conn != null && !conn.isClosed())  
                                         conn.close();  
                         } catch (Exception e) {}  
                 }  
   
                 return station;  
         }  
   
182  }  }

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

  ViewVC Help
Powered by ViewVC 1.1.20