28 |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
import dk.daoas.daoadresseservice.beans.SearchResult.Status; |
29 |
import dk.daoas.daoadresseservice.db.DatabaseLayer; |
import dk.daoas.daoadresseservice.db.DatabaseLayer; |
30 |
import dk.daoas.daoadresseservice.util.DeduplicateHelper; |
import dk.daoas.daoadresseservice.util.DeduplicateHelper; |
31 |
|
import dk.daoas.daoadresseservice.util.NaturalOrderComparator; |
32 |
|
|
33 |
public class AddressSearch { |
public class AddressSearch { |
34 |
|
|
58 |
|
|
59 |
|
|
60 |
public SearchResult search(String postnrStr, String adresse) { |
public SearchResult search(String postnrStr, String adresse) { |
61 |
|
|
62 |
|
postnrStr = postnrStr.trim(); |
63 |
|
adresse = adresse.trim(); |
64 |
|
|
65 |
|
|
66 |
SearchRequest request = new SearchRequest(); |
SearchRequest request = new SearchRequest(); |
67 |
SearchResult result = new SearchResult(); |
SearchResult result = new SearchResult(); |
68 |
|
|
99 |
|
|
100 |
|
|
101 |
if (request.vasketVejnavn.indexOf("pakkebo") > -1 |
if (request.vasketVejnavn.indexOf("pakkebo") > -1 |
102 |
|
|| request.vasketVejnavn.indexOf("pakkepost") > -1 |
103 |
|| request.vasketVejnavn.indexOf("døgnpost") > -1 |
|| request.vasketVejnavn.indexOf("døgnpost") > -1 |
104 |
|| request.vasketVejnavn.indexOf("døgnbo") > -1 |
|| request.vasketVejnavn.indexOf("døgnbo") > -1 |
105 |
|| request.vasketVejnavn.equals("id") |
|| request.vasketVejnavn.equals("id") |
307 |
if (orgAddress == null) |
if (orgAddress == null) |
308 |
continue; |
continue; |
309 |
|
|
310 |
|
if (orgAddress.daekningsType != DaekningsType.DAEKNING_IKKEDAEKKET) { |
311 |
|
//kan være at adressen er blevet markeret dækket og - find-nærmeste data ikke er opdateret i mellemtiden |
312 |
|
continue; |
313 |
|
} |
314 |
|
|
315 |
Address targetAddress = idAddressMap.get(eb.targetId); |
Address targetAddress = idAddressMap.get(eb.targetId); |
316 |
if (targetAddress == null) |
if (targetAddress == null) { |
317 |
continue; |
continue; |
318 |
|
} |
319 |
|
|
320 |
if (orgAddress.distributor != null && orgAddress.distributor.equals("LUKKET")) { |
|
321 |
|
if ( StringUtils.equals(orgAddress.distributor, "LUKKET") ) { |
322 |
continue; |
continue; |
323 |
} |
} |
324 |
|
|
325 |
if (targetAddress.distributor.equals("LUKKET")) { |
|
326 |
|
|
327 |
|
if ( StringUtils.equals(targetAddress.distributor, "LUKKET") ) { |
328 |
continue; |
continue; |
329 |
} |
} |
330 |
|
|
519 |
aliasSet.add(vejnavn.replace("alle", "allé") ); |
aliasSet.add(vejnavn.replace("alle", "allé") ); |
520 |
aliasSet.add(vejnavn.replace("allé", "alle") ); |
aliasSet.add(vejnavn.replace("allé", "alle") ); |
521 |
|
|
522 |
|
|
523 |
|
// forkortelser |
524 |
aliasSet.add(vejnavn.replace("dronningens", "dr") ); |
aliasSet.add(vejnavn.replace("dronningens", "dr") ); |
525 |
aliasSet.add(vejnavn.replace("dr.", "dronningens") ); |
aliasSet.add(vejnavn.replace("dr.", "dronningens") ); |
526 |
aliasSet.add(vejnavn.replace("dr ", "dronningens") ); |
aliasSet.add(vejnavn.replace("dr ", "dronningens") ); |
555 |
|
|
556 |
aliasSet.add(vejnavn.replace("nordre", "ndr") ); |
aliasSet.add(vejnavn.replace("nordre", "ndr") ); |
557 |
aliasSet.add(vejnavn.replace("ndr", "nordre") ); |
aliasSet.add(vejnavn.replace("ndr", "nordre") ); |
558 |
|
|
559 |
|
aliasSet.add(vejnavn.replace("borgmester", "borgm") ); |
560 |
|
aliasSet.add(vejnavn.replace("borgm", "borgmester") ); |
561 |
|
|
562 |
|
|
563 |
aliasSet.add(vejnavn.replace("sankt", "skt") ); |
aliasSet.add(vejnavn.replace("sankt", "skt") ); |
564 |
aliasSet.add(vejnavn.replace("sankt", "sct") ); |
aliasSet.add(vejnavn.replace("sankt", "sct") ); |
565 |
aliasSet.add(vejnavn.replace("skt", "sankt") ); |
aliasSet.add(vejnavn.replace("skt", "sankt") ); |
566 |
|
|
567 |
aliasSet.add(vejnavn.replace("skt", "sct") ); |
aliasSet.add(vejnavn.replace("skt", "sct") ); |
568 |
aliasSet.add(vejnavn.replace("sct", "skt") ); |
aliasSet.add(vejnavn.replace("sct", "skt") ); |
569 |
|
|
570 |
|
|
571 |
|
|
572 |
// fornavn forkortelser |
// fornavn forkortelser |
573 |
aliasSet.add(vejnavn.replace("john", "j") ); |
aliasSet.add(vejnavn.replace("john", "j") ); |
574 |
aliasSet.add(vejnavn.replace("thomas", "th") ); |
aliasSet.add(vejnavn.replace("thomas", "th") ); |
575 |
aliasSet.add(vejnavn.replace("thorvald", "th") ); |
aliasSet.add(vejnavn.replace("thorvald", "th") ); |
576 |
|
|
577 |
|
|
578 |
|
aliasSet.add(vejnavn.replace("christian", "chr") ); |
579 |
|
aliasSet.add(vejnavn.replace("kristian", "kr") ); |
580 |
|
|
581 |
|
|
582 |
|
// alternative stavninger |
583 |
|
aliasSet.add(vejnavn.replace("peder", "peter") ); |
584 |
|
aliasSet.add(vejnavn.replace("peter", "peder") ); |
585 |
|
|
586 |
|
|
587 |
|
|
588 |
// Romertal |
// Romertal |
624 |
aliasSet.add(vejnavn.replace("vej", "vejen") ); |
aliasSet.add(vejnavn.replace("vej", "vejen") ); |
625 |
aliasSet.add(vejnavn.replace("vejen", "vej") ); |
aliasSet.add(vejnavn.replace("vejen", "vej") ); |
626 |
|
|
627 |
|
aliasSet.add(vejnavn.replace("v", "vej") );//Vi kan have vejnavne i DB der bare slutter på v istedet for vej |
628 |
|
|
629 |
aliasSet.add(vejnavn.replace("alle", "all") ); |
aliasSet.add(vejnavn.replace("alle", "all") ); |
630 |
aliasSet.add(vejnavn.replace("allé", "all") ); |
aliasSet.add(vejnavn.replace("allé", "all") ); |
631 |
aliasSet.add(vejnavn.replace("alle", "allú") ); //Fundet i logs.hentruteinfo |
aliasSet.add(vejnavn.replace("alle", "allú") ); //Fundet i logs.hentruteinfo |
685 |
public Set<String> getHusnumre(int gadeid) { |
public Set<String> getHusnumre(int gadeid) { |
686 |
|
|
687 |
Map<String, Address> gade = searchGadeidentAdresser.get(gadeid); |
Map<String, Address> gade = searchGadeidentAdresser.get(gadeid); |
688 |
return new TreeSet<String>( gade.keySet() ); |
|
689 |
|
Set<String> set = new TreeSet<String>( new NaturalOrderComparator<String>() ); |
690 |
|
set.addAll( gade.keySet() ); |
691 |
|
|
692 |
|
return set; |
693 |
} |
} |
694 |
|
|
695 |
public Address getAdresse(int gadeid, String husnr) { |
public Address getAdresse(int gadeid, String husnr) { |