1 |
package dk.daoas.daoadresseservice; |
package dk.daoas.daoadresseservice; |
2 |
|
|
3 |
import java.io.IOException; |
import java.io.IOException; |
4 |
import java.io.UnsupportedEncodingException; |
import java.util.Arrays; |
5 |
|
import java.util.List; |
6 |
|
|
7 |
import javax.servlet.ServletException; |
import javax.servlet.ServletException; |
8 |
import javax.servlet.annotation.WebServlet; |
import javax.servlet.annotation.WebServlet; |
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 org.apache.commons.lang3.StringUtils; |
14 |
|
|
15 |
|
import dk.daoas.daoadresseservice.beans.Address; |
16 |
import dk.daoas.daoadresseservice.beans.SearchResult; |
import dk.daoas.daoadresseservice.beans.SearchResult; |
17 |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
18 |
|
import dk.daoas.daoadresseservice.db.LogPersistance; |
19 |
|
|
20 |
/** |
/** |
21 |
* Servlet implementation class SearchServlet |
* Denne servlet forventer at Tomcat connector'en er konfigureret med |
22 |
|
* URIEncoding="UTF-8" |
23 |
*/ |
*/ |
24 |
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1) |
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1) |
25 |
public class SearchServlet extends HttpServlet { |
public class SearchServlet extends HttpServlet { |
26 |
|
|
27 |
|
private static final long serialVersionUID = 1L; |
28 |
|
|
29 |
|
|
30 |
|
private transient LogPersistance logPersistance; |
31 |
|
//transient ServiceConfig config; |
32 |
|
|
33 |
|
private List<String> daekingstyper = Arrays.asList( new String[] { |
34 |
|
"H","L","S", //de gamle |
35 |
|
"MA","TI","ON","TO","FR","LO","SO" |
36 |
|
} ); |
37 |
|
|
38 |
@Override |
@Override |
39 |
public void init() throws ServletException { |
public void init() throws ServletException { |
40 |
super.init(); |
super.init(); |
41 |
|
|
42 |
|
//config = (ServiceConfig) this.getServletContext().getAttribute("config"); |
43 |
|
logPersistance = new LogPersistance(); |
44 |
|
|
45 |
System.out.println("SearchServlet loaded"); |
System.out.println("SearchServlet loaded"); |
46 |
} |
} |
47 |
|
|
48 |
|
@Override |
49 |
private static final long serialVersionUID = 1L; |
public void destroy() { |
50 |
|
super.destroy(); |
51 |
String getUtf8(String str) throws UnsupportedEncodingException { |
|
52 |
return new String( str.getBytes("iso-8859-1"), "UTF-8"); |
if (logPersistance != null) { |
53 |
|
logPersistance.shutdown(); |
54 |
|
} |
55 |
|
System.out.println("SearchServlet destroyed"); |
56 |
} |
} |
57 |
|
|
58 |
|
|
59 |
|
|
60 |
|
|
61 |
|
|
62 |
|
|
63 |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
64 |
//long start1 = System.currentTimeMillis(); |
|
65 |
AdressSearch search = (AdressSearch) this.getServletContext().getAttribute("search"); |
response.setHeader("Access-Control-Allow-Origin", "*"); //Allow ajax calls from everywhere |
66 |
request.setCharacterEncoding("UTF-8"); |
|
67 |
|
AddressSearch search = (AddressSearch) this.getServletContext().getAttribute("search"); |
68 |
|
if (search == null) { |
69 |
|
System.out.println("Recieved request while loading data"); |
70 |
|
|
71 |
|
response.setContentType("text/xml; charset=UTF-8"); |
72 |
|
response.getWriter().print( generateErrorXML("Service not ready") ); |
73 |
|
return; |
74 |
|
} |
75 |
|
|
76 |
String brugerid = request.getParameter("brugerid"); |
String brugerid = request.getParameter("brugerid"); |
77 |
String postnr = request.getParameter("postnr"); |
String postnr = request.getParameter("postnr"); |
|
//String adresseStr = getUtf8( request.getParameter("adresse") ); |
|
78 |
String adresseStr = request.getParameter("adresse"); |
String adresseStr = request.getParameter("adresse"); |
79 |
|
String omdeling = request.getParameter("omdeling"); |
80 |
|
|
81 |
|
|
82 |
|
String naermesteHusnrStr = request.getParameter("naermestehusnr"); |
83 |
|
|
84 |
|
if (postnr == null) { |
85 |
|
response.setContentType("text/xml; charset=UTF-8"); |
86 |
|
response.getWriter().print( generateErrorXML("Mangler postnr parameter") ); |
87 |
|
return; |
88 |
|
} |
89 |
|
|
90 |
|
if (adresseStr == null) { |
91 |
|
response.setContentType("text/xml; charset=UTF-8"); |
92 |
|
response.getWriter().print( generateErrorXML("Mangler adresse parameter") ); |
93 |
|
return; |
94 |
|
} |
95 |
|
if (brugerid == null) { |
96 |
|
brugerid = request.getRemoteHost(); |
97 |
|
} |
98 |
|
|
99 |
|
if (omdeling == null || omdeling.equals("") ) { |
100 |
|
omdeling = "H"; |
101 |
|
} |
102 |
|
|
103 |
|
if ( daekingstyper.contains(omdeling) == false ) { |
104 |
|
response.setContentType("text/xml; charset=UTF-8"); |
105 |
|
response.getWriter().print( generateErrorXML("Ugyldig omdelingsdag") ); |
106 |
|
return; |
107 |
|
} |
108 |
|
boolean naermesteHusnr; |
109 |
|
if (naermesteHusnrStr == null || naermesteHusnrStr.equals("")) { |
110 |
|
naermesteHusnr = false; |
111 |
|
} else { |
112 |
|
naermesteHusnr = Integer.parseInt( naermesteHusnrStr ) > 0; |
113 |
|
} |
114 |
|
|
115 |
|
|
116 |
|
|
117 |
//long start2 = System.currentTimeMillis(); |
SearchResult result = search.search(postnr, adresseStr, naermesteHusnr); |
|
SearchResult result = search.search(postnr, adresseStr); |
|
118 |
|
|
|
//long start3 = System.currentTimeMillis(); |
|
119 |
|
|
120 |
StringBuilder sb = new StringBuilder(); |
StringBuilder sb = new StringBuilder(); |
121 |
sb.append("<result>"); |
sb.append("<result>\n"); |
122 |
|
|
123 |
if (result.status == Status.STATUS_OK) { |
if (result.status == Status.STATUS_OK) { |
124 |
sb.append("<status>ok</status>"); |
sb.append("<status>ok</status>"); |
125 |
sb.append("<distrikt>").append(result.address.rute).append("</distrikt>"); |
} else { |
126 |
sb.append("<koreliste>").append(result.address.koreliste).append("</koreliste>"); |
sb.append("<status>error</status>"); |
127 |
sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>"); |
} |
128 |
sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>"); |
|
129 |
sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>"); |
String ruteMandag = StringUtils.defaultString(result.address.ruteMandag); //Sikre at der ikke sendes "null" tilbage |
130 |
|
String korelisteMandag = StringUtils.defaultString(result.address.korelisteMandag); //Sikre at der ikke sendes "null" tilbage |
131 |
|
String ruteTirsdag = StringUtils.defaultString(result.address.ruteTirsdag); //Sikre at der ikke sendes "null" tilbage |
132 |
|
String korelisteTirsdag = StringUtils.defaultString(result.address.korelisteTirsdag); //Sikre at der ikke sendes "null" tilbage |
133 |
|
String ruteOnsdag = StringUtils.defaultString(result.address.ruteOnsdag); //Sikre at der ikke sendes "null" tilbage |
134 |
|
String korelisteOnsdag = StringUtils.defaultString(result.address.korelisteOnsdag); //Sikre at der ikke sendes "null" tilbage |
135 |
|
String ruteTorsdag = StringUtils.defaultString(result.address.ruteTorsdag); //Sikre at der ikke sendes "null" tilbage |
136 |
|
String korelisteTorsdag = StringUtils.defaultString(result.address.korelisteTorsdag); //Sikre at der ikke sendes "null" tilbage |
137 |
|
String ruteFredag = StringUtils.defaultString(result.address.ruteFredag); //Sikre at der ikke sendes "null" tilbage |
138 |
|
String korelisteFredag = StringUtils.defaultString(result.address.korelisteFredag); //Sikre at der ikke sendes "null" tilbage |
139 |
|
|
140 |
|
String ruteLordag = StringUtils.defaultString(result.address.ruteLordag); //Sikre at der ikke sendes "null" tilbage |
141 |
|
String korelisteLordag = StringUtils.defaultString(result.address.korelisteLordag); //Sikre at der ikke sendes "null" tilbage |
142 |
|
|
143 |
|
String ruteSondag = StringUtils.defaultString(result.address.ruteSondag); //Sikre at der ikke sendes "null" tilbage |
144 |
|
String korelisteSondag = StringUtils.defaultString(result.address.korelisteSondag); //Sikre at der ikke sendes "null" tilbage |
145 |
|
|
146 |
//Extra information |
sb.append("<error>").append( result.status ).append("</error>"); |
147 |
sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>"); |
|
148 |
sb.append("<distributor>").append(result.address.distributor).append("</distributor>"); |
|
149 |
|
|
150 |
|
String valgtRute = ruteMandag; //Default til hverdag/mandags oplysningerne |
151 |
|
String valgtKoreliste = ruteMandag; |
152 |
|
|
153 |
|
if (omdeling.equals("TI") && ruteTirsdag.equals("") == false){ |
154 |
|
valgtRute = ruteTirsdag; |
155 |
|
valgtKoreliste = korelisteTirsdag; |
156 |
|
} |
157 |
|
if (omdeling.equals("ON") && ruteTirsdag.equals("") == false){ |
158 |
|
valgtRute = ruteOnsdag; |
159 |
|
valgtKoreliste = ruteOnsdag; |
160 |
|
} |
161 |
|
if (omdeling.equals("TO") && ruteTirsdag.equals("") == false){ |
162 |
|
valgtRute = ruteTorsdag; |
163 |
|
valgtKoreliste = korelisteTorsdag; |
164 |
|
} |
165 |
|
if (omdeling.equals("FR") && ruteTirsdag.equals("") == false){ |
166 |
|
valgtRute = ruteFredag; |
167 |
|
valgtKoreliste = korelisteFredag; |
168 |
|
} |
169 |
|
if ( (omdeling.equals("L") || omdeling.equals("LO")) && ruteLordag.equals("") == false){ |
170 |
|
valgtRute = ruteLordag; |
171 |
|
valgtKoreliste = korelisteLordag; |
172 |
|
} |
173 |
|
if ( (omdeling.equals("S") || omdeling.equals("SO")) && ruteSondag.equals("") == false) { |
174 |
|
valgtRute = ruteSondag; |
175 |
|
valgtKoreliste = korelisteSondag; |
176 |
|
} |
177 |
|
|
178 |
|
sb.append("<distrikt>").append( valgtRute ).append("</distrikt>"); |
179 |
|
sb.append("<koreliste>").append( valgtKoreliste ).append("</koreliste>"); |
180 |
|
|
181 |
|
|
182 |
|
sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>"); |
183 |
|
sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>"); |
184 |
|
sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>"); |
185 |
|
sb.append("\n"); |
186 |
|
|
187 |
|
//Extra information |
188 |
|
sb.append("<split>"); |
189 |
|
sb.append("<vej>").append( result.splitResult.vej).append("</vej>"); |
190 |
|
sb.append("<husnr>").append( result.splitResult.husnr).append("</husnr>"); |
191 |
|
sb.append("<litra>").append( result.splitResult.litra).append("</litra>"); |
192 |
|
sb.append("<etage>").append( result.splitResult.etage).append("</etage>"); //sal |
193 |
|
sb.append("<lejlighed>").append( result.splitResult.lejlighed).append("</lejlighed>"); //side |
194 |
|
sb.append("</split>"); |
195 |
|
|
196 |
|
sb.append("<vasketvejnavn>").append( result.vasketVejnavn ).append("</vasketvejnavn>"); |
197 |
|
|
198 |
|
sb.append("<gadeident>").append( result.gadeident ).append("</gadeident>"); |
199 |
|
sb.append("<vejnavn>").append(result.vej).append("</vejnavn>"); |
200 |
|
|
201 |
|
sb.append("<latitude>").append(result.address.latitude).append("</latitude>"); |
202 |
|
sb.append("<longitude>").append(result.address.longitude).append("</longitude>"); |
203 |
|
|
204 |
|
sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>"); |
205 |
|
sb.append("<distributor>").append(result.address.distributor).append("</distributor>"); |
206 |
|
if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) { |
207 |
sb.append("<extafstand>").append(result.address.extAfstand).append("</extafstand>"); |
sb.append("<extafstand>").append(result.address.extAfstand).append("</extafstand>"); |
208 |
|
|
209 |
} else { |
Address t = result.address.extTarget; |
210 |
sb.append("<status>error</status>"); |
sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav).append("</extaddr>"); |
211 |
sb.append("<error>").append( result.status ).append("</error>"); |
sb.append("<extpost>").append(t.postnr).append("</extpost>"); |
212 |
|
sb.append("<extpos>").append(t.latitude).append(",").append(t.longitude).append("</extpos>"); |
213 |
} |
} |
214 |
|
|
215 |
|
sb.append("<mandag>").append(ruteMandag).append(" ").append(korelisteMandag).append("</mandag>"); |
216 |
|
sb.append("<tirsdag>").append(ruteMandag).append(" ").append(korelisteMandag).append("</tirsdag>"); |
217 |
|
sb.append("<onsdag>").append(ruteMandag).append(" ").append(korelisteMandag).append("</onsdag>"); |
218 |
|
sb.append("<torsdag>").append(ruteMandag).append(" ").append(korelisteMandag).append("</torsdag>"); |
219 |
|
sb.append("<fredag>").append(ruteMandag).append(" ").append(korelisteMandag).append("</fredag>"); |
220 |
|
sb.append("<loerdag>").append(ruteLordag).append(" ").append(korelisteLordag).append("</loerdag>"); |
221 |
|
sb.append("<soendag>").append(ruteSondag).append(" ").append(korelisteSondag).append("</soendag>"); |
222 |
|
|
223 |
|
|
224 |
|
|
225 |
|
sb.append("<nearesthusnr>").append(result.nearestHusnr).append("</nearesthusnr>"); |
226 |
|
sb.append("<anvendthusnr>").append(result.anvendtHusnr).append("</anvendthusnr>"); |
227 |
|
sb.append("<nearestlitra>").append(result.nearestLitra).append("</nearestlitra>"); |
228 |
|
|
229 |
|
|
230 |
|
sb.append("<levenshtein>").append(result.levenshtein).append("</levenshtein>"); |
231 |
|
sb.append("<levenshteindistance>").append(result.levenshteinDistance).append("</levenshteindistance>"); |
232 |
|
|
233 |
|
sb.append("<metaphone>").append(result.metaphone).append("</metaphone>"); |
234 |
|
sb.append("<metaphonevej>").append(result.metaphoneVej).append("</metaphonevej>"); |
235 |
|
|
236 |
|
sb.append("<osm>").append(result.osm).append("</osm>"); |
237 |
|
sb.append("<osmvej>").append(result.osmVej).append("</osmvej>"); |
238 |
|
|
239 |
|
sb.append("<google>").append(result.google).append("</google>"); |
240 |
|
sb.append("<googlevej>").append(result.googleVej).append("</googlevej>"); |
241 |
|
|
242 |
|
|
243 |
sb.append("</result>"); |
sb.append("</result>"); |
244 |
|
|
245 |
response.setContentType("text/xml; charset=UTF-8"); |
response.setContentType("text/xml; charset=UTF-8"); |
246 |
response.getWriter().print( sb ); |
response.getWriter().print( sb ); |
247 |
|
|
248 |
|
logPersistance.saveRequestLog(search.getDatabaseLayer(), brugerid, postnr, adresseStr, omdeling, result); |
249 |
|
|
250 |
|
} |
251 |
|
|
252 |
/* |
public static String generateErrorXML(String msg) { |
253 |
long start4 = System.currentTimeMillis(); |
StringBuilder sb = new StringBuilder(); |
254 |
System.out.println("Servlet2:" + (start2-start1) ); |
sb.append("<result>"); |
255 |
System.out.println("Servlet3:" + (start3-start1) ); |
sb.append("<status>error</status>"); |
256 |
System.out.println("Servlet4:" + (start4-start1) ); |
sb.append("<error>").append(msg).append("</error>"); |
257 |
*/ |
sb.append("</result>"); |
258 |
|
|
259 |
|
return sb.toString(); |
260 |
|
|
261 |
} |
} |
262 |
|
|
263 |
} |
} |