--- dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java 2015/05/21 08:06:16 2550
+++ dao/DaoAdresseService/src/main/java/dk/daoas/daoadresseservice/SearchServlet.java 2015/11/26 14:25:41 2785
@@ -54,6 +54,8 @@
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
+
+ response.setHeader("Access-Control-Allow-Origin", "*"); //Allow ajax calls from everywhere
AddressSearch search = (AddressSearch) this.getServletContext().getAttribute("search");
if (search == null) {
@@ -67,6 +69,9 @@
String adresseStr = request.getParameter("adresse");
String omdeling = request.getParameter("omdeling");
+
+ String naermesteHusnrStr = request.getParameter("naermestehusnr");
+
if (postnr == null) {
response.setContentType("text/xml; charset=UTF-8");
response.getWriter().print( generateErrorXML("Mangler postnr parameter") );
@@ -91,8 +96,16 @@
response.getWriter().print( generateErrorXML("Ugyldig omdelingsdag - Kun H, L og S er gyldig") );
return;
}
+ boolean naermesteHusnr;
+ if (naermesteHusnrStr == null || naermesteHusnrStr.equals("")) {
+ naermesteHusnr = false;
+ } else {
+ naermesteHusnr = Integer.parseInt( naermesteHusnrStr ) > 0;
+ }
+
+
- SearchResult result = search.search(postnr, adresseStr);
+ SearchResult result = search.search(postnr, adresseStr, naermesteHusnr);
StringBuilder sb = new StringBuilder();
@@ -115,17 +128,24 @@
sb.append("").append( result.status ).append("");
- if (omdeling.equals("H")) { //Hverdag
- sb.append("").append( rute ).append("");
- sb.append("").append( koreliste ).append("");
- } else if (omdeling.equals("L")){
- sb.append("").append( ruteLordag ).append("");
- sb.append("").append( korelisteLordag ).append("");
- } else {
- sb.append("").append( ruteSondag ).append("");
- sb.append("").append( korelisteSondag ).append("");
+
+
+ String valgtRute = rute; //Default til hverdags oplysningerne
+ String valgtKoreliste = koreliste;
+
+
+ if (omdeling.equals("L") && ruteLordag.equals("") == false){
+ valgtRute = ruteLordag;
+ valgtKoreliste = korelisteLordag;
+ }
+ if (omdeling.equals("S") && ruteSondag.equals("") == false) {
+ valgtRute = ruteSondag;
+ valgtKoreliste = korelisteSondag;
}
+ sb.append("").append( valgtRute ).append("");
+ sb.append("").append( valgtKoreliste ).append("");
+
sb.append("").append(result.address.kommunekode).append("");
sb.append("").append(result.address.vejkode).append("");
@@ -156,6 +176,7 @@
Address t = result.address.extTarget;
sb.append("").append(t.vejnavn + " " + t.husnr + t.husnrbogstav + ", " + t.postnr).append("");
+ sb.append("").append(t.latitude).append(",").append(t.longitude).append("");
}
sb.append("").append(rute).append(" ").append(koreliste).append("");
@@ -163,7 +184,17 @@
sb.append("").append(ruteSondag).append(" ").append(korelisteSondag).append("");
+
+ sb.append("").append(result.nearestHusnr).append("");
+ sb.append("").append(result.anvendtHusnr).append("");
+ sb.append("").append(result.nearestLitra).append("");
+
+
sb.append("").append(result.levenshtein).append("");
+ sb.append("").append(result.levenshteinDistance).append("");
+
+ sb.append("").append(result.metaphone).append("");
+ sb.append("").append(result.metaphoneVej).append("");
sb.append("").append(result.osm).append("");
sb.append("").append(result.osmVej).append("");
@@ -177,11 +208,11 @@
response.setContentType("text/xml; charset=UTF-8");
response.getWriter().print( sb );
- logPersistance.saveRequestLog(brugerid, postnr, adresseStr, result);
+ logPersistance.saveRequestLog(search.getDatabaseLayer(), brugerid, postnr, adresseStr, omdeling, result);
}
- private String generateErrorXML(String msg) {
+ public static String generateErrorXML(String msg) {
StringBuilder sb = new StringBuilder();
sb.append("");
sb.append("error");