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.circuitbreaker.CircuitBreakerException; |
14 |
|
|
15 |
/** |
/** |
16 |
* Servlet implementation class TimetableServlet |
* Servlet implementation class TimetableServlet |
17 |
*/ |
*/ |
23 |
|
|
24 |
TimetableFetcher fetcher = new TimetableFetcher(); |
TimetableFetcher fetcher = new TimetableFetcher(); |
25 |
|
|
26 |
|
@Override |
27 |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
28 |
|
if (request.getParameter("train") == null) { |
29 |
|
response.sendError(400, "not enough parameters"); |
30 |
|
return; |
31 |
|
} |
32 |
|
|
33 |
String train = request.getParameter("train").trim(); |
String train = request.getParameter("train").trim(); |
34 |
|
|
35 |
String sections[] = train.split(" "); |
String sections[] = train.split(" "); |
42 |
String trainID = sections[1]; |
String trainID = sections[1]; |
43 |
try |
try |
44 |
{ |
{ |
45 |
List<TimetableBean> timetable = fetcher.lookupTimetable(trainID, type); |
List<TimetableBean> timetable = fetcher.cachedLookupTimetable(trainID, type); |
46 |
|
|
47 |
String responseXML = formatTimetable(timetable); |
String responseXML = formatTimetable(timetable); |
48 |
|
|
49 |
response.setContentType("text/xml"); |
response.setContentType("text/xml"); |
50 |
response.getWriter().print(responseXML); |
response.getWriter().print(responseXML); |
51 |
} catch (java.net.SocketTimeoutException ste) { |
} catch (java.io.IOException ioe) { |
52 |
logger.warning("(timetable) Read timed out, train="+train); |
logger.warning("(timetable) Read failed, train="+train + ". " + ioe.getMessage()); |
53 |
response.sendError(500, "Backend timed out"); |
response.sendError(500, "Backend timed out"); |
54 |
} catch (Exception e) { |
} catch (CircuitBreakerException cbe) { |
55 |
|
logger.warning("Circuitbreaker - failing fast"); |
56 |
|
response.sendError(500); |
57 |
|
}catch (Exception e) { |
58 |
logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e); |
logger.log(Level.WARNING, "failure looking up timetable: train=" +train, e); |
59 |
response.sendError(500); |
response.sendError(500); |
60 |
} |
} |