--- 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");