1 |
torben |
2274 |
package dk.daoas.daoadresseservice;
|
2 |
|
|
|
3 |
|
|
import java.io.IOException;
|
4 |
|
|
|
5 |
|
|
import javax.servlet.ServletException;
|
6 |
|
|
import javax.servlet.annotation.WebServlet;
|
7 |
|
|
import javax.servlet.http.HttpServlet;
|
8 |
|
|
import javax.servlet.http.HttpServletRequest;
|
9 |
|
|
import javax.servlet.http.HttpServletResponse;
|
10 |
|
|
|
11 |
torben |
2506 |
import org.apache.commons.lang3.StringUtils;
|
12 |
|
|
|
13 |
torben |
2290 |
import dk.daoas.daoadresseservice.beans.Address;
|
14 |
torben |
2282 |
import dk.daoas.daoadresseservice.beans.SearchResult;
|
15 |
|
|
import dk.daoas.daoadresseservice.beans.SearchResult.Status;
|
16 |
torben |
2372 |
import dk.daoas.daoadresseservice.db.LogPersistance;
|
17 |
torben |
2274 |
|
18 |
|
|
/**
|
19 |
torben |
2311 |
* Denne servlet forventer at Tomcat connector'en er konfigureret med
|
20 |
|
|
* URIEncoding="UTF-8"
|
21 |
torben |
2274 |
*/
|
22 |
torben |
2277 |
@WebServlet(urlPatterns = { "/SearchServlet", "/search" }, loadOnStartup = 1)
|
23 |
torben |
2274 |
public class SearchServlet extends HttpServlet {
|
24 |
torben |
2278 |
|
25 |
torben |
2372 |
private static final long serialVersionUID = 1L;
|
26 |
torben |
2346 |
|
27 |
torben |
2540 |
|
28 |
|
|
private transient LogPersistance logPersistance;
|
29 |
|
|
//transient ServiceConfig config;
|
30 |
|
|
|
31 |
torben |
2278 |
@Override
|
32 |
|
|
public void init() throws ServletException {
|
33 |
|
|
super.init();
|
34 |
torben |
2346 |
|
35 |
torben |
2540 |
//config = (ServiceConfig) this.getServletContext().getAttribute("config");
|
36 |
torben |
2372 |
logPersistance = new LogPersistance();
|
37 |
torben |
2346 |
|
38 |
torben |
2278 |
System.out.println("SearchServlet loaded");
|
39 |
|
|
}
|
40 |
torben |
2274 |
|
41 |
torben |
2375 |
@Override
|
42 |
|
|
public void destroy() {
|
43 |
|
|
super.destroy();
|
44 |
|
|
|
45 |
|
|
if (logPersistance != null) {
|
46 |
|
|
logPersistance.shutdown();
|
47 |
|
|
}
|
48 |
|
|
System.out.println("SearchServlet destroyed");
|
49 |
|
|
}
|
50 |
|
|
|
51 |
|
|
|
52 |
|
|
|
53 |
|
|
|
54 |
|
|
|
55 |
|
|
|
56 |
torben |
2274 |
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
|
57 |
torben |
2299 |
|
58 |
torben |
2410 |
AddressSearch search = (AddressSearch) this.getServletContext().getAttribute("search");
|
59 |
torben |
2299 |
if (search == null) {
|
60 |
|
|
response.setContentType("text/xml; charset=UTF-8");
|
61 |
torben |
2374 |
response.getWriter().print( generateErrorXML("Service not ready") );
|
62 |
|
|
return;
|
63 |
torben |
2299 |
}
|
64 |
torben |
2274 |
|
65 |
|
|
String brugerid = request.getParameter("brugerid");
|
66 |
|
|
String postnr = request.getParameter("postnr");
|
67 |
torben |
2287 |
String adresseStr = request.getParameter("adresse");
|
68 |
torben |
2545 |
String omdeling = request.getParameter("omdeling");
|
69 |
torben |
2374 |
|
70 |
|
|
if (postnr == null) {
|
71 |
|
|
response.setContentType("text/xml; charset=UTF-8");
|
72 |
|
|
response.getWriter().print( generateErrorXML("Mangler postnr parameter") );
|
73 |
|
|
return;
|
74 |
|
|
}
|
75 |
|
|
|
76 |
|
|
if (adresseStr == null) {
|
77 |
|
|
response.setContentType("text/xml; charset=UTF-8");
|
78 |
|
|
response.getWriter().print( generateErrorXML("Mangler adresse parameter") );
|
79 |
|
|
return;
|
80 |
|
|
}
|
81 |
|
|
if (brugerid == null) {
|
82 |
|
|
brugerid = request.getRemoteHost();
|
83 |
|
|
}
|
84 |
torben |
2545 |
|
85 |
|
|
if (omdeling == null || omdeling.equals("") ) {
|
86 |
|
|
omdeling = "H";
|
87 |
|
|
}
|
88 |
|
|
|
89 |
torben |
2547 |
if ( omdeling.equals("H") == false && omdeling.equals("L") == false && omdeling.equals("S") == false ) {
|
90 |
torben |
2545 |
response.setContentType("text/xml; charset=UTF-8");
|
91 |
torben |
2547 |
response.getWriter().print( generateErrorXML("Ugyldig omdelingsdag - Kun H, L og S er gyldig") );
|
92 |
torben |
2545 |
return;
|
93 |
|
|
}
|
94 |
torben |
2274 |
|
95 |
torben |
2350 |
SearchResult result = search.search(postnr, adresseStr);
|
96 |
torben |
2274 |
|
97 |
torben |
2288 |
|
98 |
torben |
2274 |
StringBuilder sb = new StringBuilder();
|
99 |
torben |
2294 |
sb.append("<result>\n");
|
100 |
torben |
2274 |
|
101 |
|
|
if (result.status == Status.STATUS_OK) {
|
102 |
|
|
sb.append("<status>ok</status>");
|
103 |
|
|
} else {
|
104 |
|
|
sb.append("<status>error</status>");
|
105 |
|
|
}
|
106 |
torben |
2506 |
|
107 |
|
|
String rute = StringUtils.defaultString(result.address.rute); //Sikre at der ikke sendes "null" tilbage
|
108 |
|
|
String koreliste = StringUtils.defaultString(result.address.koreliste); //Sikre at der ikke sendes "null" tilbage
|
109 |
torben |
2547 |
|
110 |
|
|
String ruteLordag = StringUtils.defaultString(result.address.ruteLordag); //Sikre at der ikke sendes "null" tilbage
|
111 |
|
|
String korelisteLordag = StringUtils.defaultString(result.address.korelisteLordag); //Sikre at der ikke sendes "null" tilbage
|
112 |
torben |
2545 |
|
113 |
|
|
String ruteSondag = StringUtils.defaultString(result.address.ruteSondag); //Sikre at der ikke sendes "null" tilbage
|
114 |
|
|
String korelisteSondag = StringUtils.defaultString(result.address.korelisteSondag); //Sikre at der ikke sendes "null" tilbage
|
115 |
torben |
2397 |
|
116 |
|
|
sb.append("<error>").append( result.status ).append("</error>");
|
117 |
torben |
2545 |
|
118 |
|
|
if (omdeling.equals("H")) { //Hverdag
|
119 |
|
|
sb.append("<distrikt>").append( rute ).append("</distrikt>");
|
120 |
|
|
sb.append("<koreliste>").append( koreliste ).append("</koreliste>");
|
121 |
torben |
2547 |
} else if (omdeling.equals("L")){
|
122 |
|
|
sb.append("<distrikt>").append( ruteLordag ).append("</distrikt>");
|
123 |
|
|
sb.append("<koreliste>").append( korelisteLordag ).append("</koreliste>");
|
124 |
torben |
2545 |
} else {
|
125 |
|
|
sb.append("<distrikt>").append( ruteSondag ).append("</distrikt>");
|
126 |
|
|
sb.append("<koreliste>").append( korelisteSondag ).append("</koreliste>");
|
127 |
|
|
}
|
128 |
|
|
|
129 |
|
|
|
130 |
torben |
2397 |
sb.append("<kommunekode>").append(result.address.kommunekode).append("</kommunekode>");
|
131 |
|
|
sb.append("<vejkode>").append(result.address.vejkode).append("</vejkode>");
|
132 |
|
|
sb.append("<dbkbane>").append(result.address.dbkBane).append("</dbkbane>");
|
133 |
|
|
sb.append("\n");
|
134 |
|
|
|
135 |
|
|
//Extra information
|
136 |
torben |
2444 |
sb.append("<split>");
|
137 |
|
|
sb.append("<vej>").append( result.splitResult.vej).append("</vej>");
|
138 |
|
|
sb.append("<husnr>").append( result.splitResult.husnr).append("</husnr>");
|
139 |
|
|
sb.append("<litra>").append( result.splitResult.litra).append("</litra>");
|
140 |
|
|
sb.append("<etage>").append( result.splitResult.etage).append("</etage>"); //sal
|
141 |
|
|
sb.append("<lejlighed>").append( result.splitResult.lejlighed).append("</lejlighed>"); //side
|
142 |
|
|
sb.append("</split>");
|
143 |
|
|
|
144 |
torben |
2550 |
sb.append("<vasketvejnavn>").append( result.vasketVejnavn ).append("</vasketvejnavn>");
|
145 |
torben |
2444 |
|
146 |
torben |
2397 |
sb.append("<gadeident>").append( result.gadeident ).append("</gadeident>");
|
147 |
torben |
2405 |
sb.append("<vejnavn>").append(result.vej).append("</vejnavn>");
|
148 |
torben |
2442 |
|
149 |
|
|
sb.append("<latitude>").append(result.address.latitude).append("</latitude>");
|
150 |
|
|
sb.append("<longitude>").append(result.address.longitude).append("</longitude>");
|
151 |
|
|
|
152 |
torben |
2546 |
sb.append("<daekning>").append(result.address.daekningsType).append("</daekning>");
|
153 |
torben |
2397 |
sb.append("<distributor>").append(result.address.distributor).append("</distributor>");
|
154 |
|
|
if (result.address.daekningsType == DaekningsType.DAEKNING_UDVIDET) {
|
155 |
|
|
sb.append("<extafstand>").append(result.address.extAfstand).append("</extafstand>");
|
156 |
|
|
|
157 |
|
|
Address t = result.address.extTarget;
|
158 |
|
|
sb.append("<extaddr>").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("</extaddr>");
|
159 |
torben |
2444 |
}
|
160 |
torben |
2397 |
|
161 |
torben |
2546 |
sb.append("<hverdag>").append(rute).append(" ").append(koreliste).append("</hverdag>");
|
162 |
torben |
2547 |
sb.append("<loerdag>").append(ruteLordag).append(" ").append(korelisteLordag).append("</loerdag>");
|
163 |
torben |
2546 |
sb.append("<soendag>").append(ruteSondag).append(" ").append(korelisteSondag).append("</soendag>");
|
164 |
|
|
|
165 |
|
|
|
166 |
torben |
2397 |
sb.append("<levenshtein>").append(result.levenshtein).append("</levenshtein>");
|
167 |
|
|
|
168 |
|
|
sb.append("<osm>").append(result.osm).append("</osm>");
|
169 |
|
|
sb.append("<osmvej>").append(result.osmVej).append("</osmvej>");
|
170 |
|
|
|
171 |
|
|
sb.append("<google>").append(result.google).append("</google>");
|
172 |
|
|
sb.append("<googlevej>").append(result.googleVej).append("</googlevej>");
|
173 |
|
|
|
174 |
|
|
|
175 |
torben |
2274 |
sb.append("</result>");
|
176 |
|
|
|
177 |
|
|
response.setContentType("text/xml; charset=UTF-8");
|
178 |
|
|
response.getWriter().print( sb );
|
179 |
|
|
|
180 |
torben |
2608 |
logPersistance.saveRequestLog(search.getDatabaseLayer(), brugerid, postnr, adresseStr, result);
|
181 |
torben |
2372 |
|
182 |
torben |
2274 |
}
|
183 |
torben |
2374 |
|
184 |
|
|
private String generateErrorXML(String msg) {
|
185 |
|
|
StringBuilder sb = new StringBuilder();
|
186 |
|
|
sb.append("<result>");
|
187 |
|
|
sb.append("<status>error</status>");
|
188 |
|
|
sb.append("<error>").append(msg).append("</error>");
|
189 |
|
|
sb.append("</result>");
|
190 |
|
|
|
191 |
|
|
return sb.toString();
|
192 |
|
|
|
193 |
|
|
}
|
194 |
torben |
2274 |
|
195 |
|
|
}
|