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

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

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

revision 421 by torben, Thu Oct 8 12:19:42 2009 UTC revision 697 by torben, Mon May 3 07:42:02 2010 UTC
# Line 10  import javax.servlet.http.HttpServlet; Line 10  import javax.servlet.http.HttpServlet;
10  import javax.servlet.http.HttpServletRequest;  import javax.servlet.http.HttpServletRequest;
11  import javax.servlet.http.HttpServletResponse;  import javax.servlet.http.HttpServletResponse;
12    
13  import dk.thoerup.curcuitbreaker.CircuitBreakerException;  import dk.thoerup.circuitbreaker.CircuitBreakerException;
14    
15  /**  /**
16   * Servlet implementation class TimetableServlet   * Servlet implementation class TimetableServlet
# Line 21  public class TimetableServlet extends Ht Line 21  public class TimetableServlet extends Ht
21                    
22          Logger logger = Logger.getLogger( TimetableServlet.class.getName() );          Logger logger = Logger.getLogger( TimetableServlet.class.getName() );
23                    
24          TimetableFetcher fetcher = new TimetableFetcher();          TimetableFetcher fetcher;
25                    
26            @Override
27            public void init() throws ServletException {
28                    super.init();
29                    
30                    boolean useTempSite =  Boolean.parseBoolean( getServletContext().getInitParameter("usetempsite") );
31                    int cacheTimeout =  Integer.parseInt( getServletContext().getInitParameter("cache_timeout") );
32                    logger.info( "TimetableServlet, use temp site=" + useTempSite + ", cache=" + cacheTimeout);
33                    fetcher = new TimetableFetcher(useTempSite,cacheTimeout);
34            }
35            
36            @Override
37          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {          protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
38                    if (request.getParameter("train") == null) {
39                            response.sendError(400, "not enough parameters");
40                            return;
41                    }
42                    
43                  String train = request.getParameter("train").trim();                  String train = request.getParameter("train").trim();
44                    String trainID;
45                    String type = request.getParameter("type");
46                                    
47                  String sections[] = train.split(" ");                  if (type != null) {
48                  if (sections.length != 2) {                           trainID = train;
49                          response.sendError(400, "Invalid parameter");                  } else { //remove this failover sometime after release of client 0.6.4
50                          return;                          String sections[] = train.split(" ");
51                            if (sections.length != 2) {
52                                    response.sendError(400, "Invalid parameter");
53                                    return;
54                            }
55                                    
56                            type = lookupType(sections[0]);
57                            trainID = sections[1];
58                  }                  }
59                                    
                 String type = lookupType(sections[0]);  
                 String trainID = sections[1];  
60                  try                  try
61                  {                  {
62                          List<TimetableBean> timetable = fetcher.cachedLookupTimetable(trainID, type);                          List<TimetableBean> timetable = fetcher.cachedLookupTimetable(trainID, type);
# Line 42  public class TimetableServlet extends Ht Line 65  public class TimetableServlet extends Ht
65                                    
66                          response.setContentType("text/xml");                          response.setContentType("text/xml");
67                          response.getWriter().print(responseXML);                          response.getWriter().print(responseXML);
68                  } catch (java.net.SocketTimeoutException ste) {                  } catch (java.io.IOException ioe) {
69                          logger.warning("(timetable) Read timed out, train="+train);                          logger.warning("(timetable) Read failed, train="+train + ". " + ioe.getMessage());
70                          response.sendError(500, "Backend timed out");                          response.sendError(500, "Backend timed out");
71                  } catch (CircuitBreakerException cbe) {                  } catch (CircuitBreakerException cbe) {
72                          logger.warning("Circuitbreaker - failing fast");                          logger.warning("Circuitbreaker - failing fast");
73                          response.sendError(500);                          response.sendError(500);
74                  }catch (Throwable e) {                  }catch (Exception e) {
75                          logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e);                          logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e);
76                          response.sendError(500);                          response.sendError(500);
77                  }                  }
78                                    
79          }          }
80                    /*remove /outcomment/deprecate after 0.6.4 release */
81          String lookupType(String trainCode) {          String lookupType(String trainCode) {
82                  trainCode = trainCode.toLowerCase();                  trainCode = trainCode.toLowerCase();
83                                    

Legend:
Removed from v.421  
changed lines
  Added in v.697

  ViewVC Help
Powered by ViewVC 1.1.20