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

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

Parent Directory Parent Directory | Revision Log Revision Log


Revision 580 - (show annotations) (download)
Tue Feb 2 18:42:38 2010 UTC (14 years, 3 months ago) by torben
File size: 6601 byte(s)
Added a screenscraper for bane.dk's temporary site
1 package dk.thoerup.traininfoservice.banedk;
2
3 import java.io.IOException;
4 import java.sql.Connection;
5 import java.sql.ResultSet;
6 import java.sql.Statement;
7 import java.util.List;
8 import java.util.logging.Level;
9 import java.util.logging.Logger;
10
11 import javax.servlet.ServletException;
12 import javax.servlet.http.HttpServlet;
13 import javax.servlet.http.HttpServletRequest;
14 import javax.servlet.http.HttpServletResponse;
15 import javax.xml.parsers.DocumentBuilder;
16 import javax.xml.parsers.DocumentBuilderFactory;
17 import javax.xml.transform.OutputKeys;
18 import javax.xml.transform.Transformer;
19 import javax.xml.transform.TransformerFactory;
20 import javax.xml.transform.dom.DOMSource;
21 import javax.xml.transform.stream.StreamResult;
22
23 import org.w3c.dom.DOMImplementation;
24 import org.w3c.dom.Document;
25 import org.w3c.dom.Element;
26
27 import dk.thoerup.circuitbreaker.CircuitBreakerException;
28 import dk.thoerup.traininfoservice.DBConnection;
29
30 /**
31 * Servlet implementation class DepartureServlet
32 */
33 public class DepartureServlet extends HttpServlet {
34 private static final long serialVersionUID = 1L;
35
36 Logger logger = Logger.getLogger( DepartureServlet.class.getName() );
37
38 DepartureFetcher fetcher;
39 TransformerFactory transformerFactory = TransformerFactory.newInstance();
40 DocumentBuilderFactory docBuilderFactory = DocumentBuilderFactory.newInstance();
41
42
43 @Override
44 public void init() throws ServletException {
45 super.init();
46
47 boolean useTempSite = Boolean.parseBoolean( getInitParameter("usetempsite") );
48 logger.info( "DepartureServlet, use temp site=" + useTempSite );
49 fetcher = new DepartureFetcher(useTempSite);
50 }
51
52 @Override
53 protected void doGet(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
54 if (req.getParameter("station") == null) {
55 resp.sendError(400, "not enough parameters");
56 return;
57 }
58
59 int station = Integer.parseInt( req.getParameter("station") );
60 String format = req.getParameter("format");
61
62 List<DepartureBean> beans;
63
64 String stationName = getStationName(station);
65
66 try {
67 beans = fetcher.cachedLookupDepartures(station);
68 } catch (java.io.IOException ioe) {
69 logger.warning("Read failed, station="+station + ". " + ioe.getMessage() );
70 resp.sendError(500);
71 return;
72 } catch (CircuitBreakerException cbe) {
73 logger.warning("Circuitbreaker - failing fast");
74 resp.sendError(500);
75 return;
76 } catch (Exception e) {
77 logger.log(Level.WARNING, "Unknown exception, station=" +station, e);
78 resp.sendError(500);
79 return;
80 }
81
82 resp.setDateHeader("Expires", 0);
83 resp.setHeader("Cache-Control", "no-cache, must-revalidate");
84
85 if (format.equalsIgnoreCase("xml")) {
86 resp.setContentType("text/xml");
87 resp.getWriter().print( formatXml(beans, stationName) );
88 } else if (format.equalsIgnoreCase("html")) {
89 req.setAttribute("stationname", stationName );
90 req.setAttribute("departurebeans", beans);
91 req.setAttribute("stationID", station );
92 getServletContext().getRequestDispatcher("/ViewDepartures.jsp").forward(req,resp);
93 } else {
94 throw new ServletException("Unknown format");
95 }
96
97 }
98
99 protected String formatXml(List<DepartureBean> beans, String stationName) throws ServletException{
100 String xml = "";
101 try {
102 DocumentBuilder builder = docBuilderFactory.newDocumentBuilder();
103 DOMImplementation impl = builder.getDOMImplementation();
104
105
106 Document doc = impl.createDocument(null,null,null);
107 Element root = doc.createElement("departureinfo");
108 root.setAttribute("station", stationName);
109 for (DepartureBean departure : beans) {
110 Element train = doc.createElement("train");
111
112 Element time = doc.createElement("time");
113 time.setTextContent( departure.getTime() );
114 train.appendChild(time);
115
116 Element updated = doc.createElement("updated");
117 updated.setTextContent( String.valueOf(departure.getUpdated()) );
118 train.appendChild(updated);
119
120 Element trainNumber = doc.createElement("trainnumber");
121 trainNumber.setTextContent( departure.getTrainNumber() );
122 train.appendChild(trainNumber);
123
124 Element destination = doc.createElement("destination");
125 destination.setTextContent( departure.getDestination());
126 train.appendChild(destination);
127
128 Element origin = doc.createElement("origin");
129 origin.setTextContent( departure.getOrigin() );
130 train.appendChild(origin);
131
132 Element location= doc.createElement("location");
133 location.setTextContent( departure.getLocation() );
134 train.appendChild(location);
135
136 Element status = doc.createElement("status");
137 status.setTextContent( departure.getStatus() );
138 train.appendChild(status);
139
140 Element note = doc.createElement("note");
141 note.setTextContent( departure.getNote() );
142 train.appendChild(note);
143
144 root.appendChild(train);
145 }
146
147 doc.appendChild(root);
148
149
150 DOMSource domSource = new DOMSource(doc);
151
152 Transformer transformer = transformerFactory.newTransformer();
153 //transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
154 transformer.setOutputProperty(OutputKeys.METHOD, "xml");
155 transformer.setOutputProperty(OutputKeys.ENCODING,"ISO-8859-1");
156 transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "4");
157 transformer.setOutputProperty(OutputKeys.INDENT, "yes");
158 java.io.StringWriter sw = new java.io.StringWriter();
159 StreamResult sr = new StreamResult(sw);
160 transformer.transform(domSource, sr);
161 xml = sw.toString();
162
163
164 } catch (Exception e) {
165 throw new ServletException(e);
166 }
167 return xml;
168 }
169
170 protected String getStationName(int stationID) {
171 String station = "";
172
173 Connection conn = null;
174 try {
175 conn = DBConnection.getConnection();
176 Statement stmt = conn.createStatement();
177 ResultSet rs = stmt.executeQuery("SELECT name FROM trainstations WHERE id=" + stationID);
178 if (rs.next()) {
179 station = rs.getString(1);
180 }
181
182 } catch (Exception e) {
183 } finally {
184 try {
185 if (conn != null && !conn.isClosed())
186 conn.close();
187 } catch (Exception e) {}
188 }
189
190 return station;
191 }
192
193 }

  ViewVC Help
Powered by ViewVC 1.1.20