/[projects]/dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AdressSearch.java
ViewVC logotype

Contents of /dao/DaoAdresseService/src/dk/daoas/daoadresseservice/AdressSearch.java

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2281 - (show annotations) (download)
Fri Feb 13 15:12:28 2015 UTC (9 years, 3 months ago) by torben
File size: 6995 byte(s)
Ingen grund til at gemme vasketVejnavn i adresse POJO'en da det bare kræver mere hukommelse
1 package dk.daoas.daoadresseservice;
2
3 import java.sql.SQLException;
4 import java.util.HashMap;
5 import java.util.List;
6 import java.util.Map;
7 import java.util.concurrent.ConcurrentHashMap;
8
9 import dk.daoas.daoadresseservice.AddressUtils.SplitResult;
10 import dk.daoas.daoadresseservice.SearchResult.Status;
11 import dk.daoas.daoadresseservice.db.DatabaseLayer;
12
13 public class AdressSearch {
14
15 Map<Integer, Map<String,Long>> searchPostnrVejnavnGadeid;
16 Map<Long, Map<String,Address>> searchGadeidentAdresser;
17
18 List<Address> alleAdresser;
19
20 /* Mapper mellem db Row ID og adresse noden */
21 Map<Integer,Address> idAddressMap;
22
23
24 Map<Integer,HundredePctBean> hundredePct;
25
26
27 public SearchResult search(String postnrStr, String adresse) {
28 int postnr=0;
29
30 try {
31 postnr = Integer.parseInt(postnrStr);
32 } catch (Exception E) {
33 return new SearchResult(Status.ERROR_UNKNOWN_POSTAL);
34 }
35
36 Map<String,Long> postnrVeje = searchPostnrVejnavnGadeid.get(postnr);
37
38 if (postnrVeje == null) {
39 return new SearchResult(Status.ERROR_UNKNOWN_POSTAL);
40 }
41
42 SplitResult split = AddressUtils.splitAdresse(adresse);
43 String vasketVejnavn = AddressUtils.vaskVejnavn( split.vej );
44
45 if (split.husnr.length() == 0) {
46 return new SearchResult(Status.ERROR_MISSING_HOUSENUMBER);
47 }
48
49 Long gadeident = postnrVeje.get(vasketVejnavn);
50 if (gadeident == null) {
51 return new SearchResult(Status.ERROR_UNKNOWN_STREETNAME);
52 }
53
54 Map<String, Address> gade = searchGadeidentAdresser.get(gadeident); //Denne søgning må ikke fejle
55
56
57 String husnrSearch = "" + split.husnr + split.litra;
58 Address addr = gade.get(husnrSearch);
59 if (addr == null) {
60 return new SearchResult(Status.ERROR_UNKNOWN_ADDRESSPOINT);
61 }
62
63 if (addr.daekningsType == DaekningsType.DAEKNING_IKKEDAEKKET) {
64 return new SearchResult(Status.STATUS_NOT_COVERED);
65 }
66
67 if (addr.distributor.equals("LUKKET")) {
68 return new SearchResult(Status.STATUS_NOT_COVERED); //Skal vi have en special status til Lukkede adresser ?
69 }
70
71
72 return new SearchResult(addr);
73 }
74
75
76 public void buildSearchStructures() throws SQLException{
77 searchPostnrVejnavnGadeid = new HashMap<Integer, Map<String,Long>>();
78 searchGadeidentAdresser = new HashMap<Long, Map<String,Address>>();
79 idAddressMap = new HashMap<Integer,Address>();
80
81 System.out.println("Build -- stage 1");
82
83 alleAdresser = DatabaseLayer.getAllAdresses();
84
85 for (Address a : alleAdresser) {
86 idAddressMap.put(a.id, a);
87
88 Map<String,Long> postnrVeje = searchPostnrVejnavnGadeid.get(a.postnr);
89
90 if (postnrVeje == null) {
91 postnrVeje = new ConcurrentHashMap<String,Long>();
92 searchPostnrVejnavnGadeid.put(a.postnr, postnrVeje);
93 }
94
95 String vasketVejnavn = AddressUtils.vaskVejnavn(a.vejnavn);
96 Long gadeident = postnrVeje.get(vasketVejnavn);
97 if (gadeident == null) {
98 postnrVeje.put(vasketVejnavn, a.gadeid);
99 }
100
101 Map<String, Address> gade = searchGadeidentAdresser.get(a.gadeid);
102 if (gade == null) {
103 gade = new HashMap<String, Address>();
104 searchGadeidentAdresser.put(a.gadeid, gade);
105 }
106 String husnrSearch = "" + a.husnr + a.husnrbogstav;
107 gade.put(husnrSearch, a);
108 }
109
110
111 ////////////////////////////////////////////////////////////////////////////////////////
112 System.out.println("Build -- stage 2 udvidet dækning");
113
114 List<ExtendedBean> extDao = DatabaseLayer.getExtendedAdresslist();
115 for (ExtendedBean eb : extDao) {
116
117 Address orgAddress = idAddressMap.get(eb.orgId);
118 if (orgAddress == null)
119 continue;
120
121 Address targetAddress = idAddressMap.get(eb.targetId);
122 if (targetAddress == null)
123 continue;
124
125 if (orgAddress.distributor != null && orgAddress.distributor.equals("LUKKET")) {
126 continue;
127 }
128
129 if (targetAddress.distributor.equals("LUKKET")) {
130 continue;
131 }
132
133 orgAddress.extTarget = targetAddress;
134 orgAddress.extAfstand = eb.afstand;
135
136 orgAddress.rute = calculateExtendedRoute(eb,orgAddress,targetAddress);
137
138 if (orgAddress.rute != null) {
139 orgAddress.daekningsType = DaekningsType.DAEKNING_UDVIDET;
140 orgAddress.koreliste = targetAddress.koreliste;
141 orgAddress.dbkBane = targetAddress.dbkBane;
142
143 /* Sådan gør den gamle service */
144 orgAddress.kommunekode = targetAddress.kommunekode;
145 orgAddress.vejkode = targetAddress.vejkode;
146
147 orgAddress.distributor = targetAddress.distributor;
148 }
149
150
151 }
152 //////////////////////////////////////////////////////////////////////////////////////
153 System.out.println("Build -- stage 3 - 100pct");
154
155 hundredePct = DatabaseLayer.get100PctList();
156 for (Address addr : alleAdresser) {
157 if (addr.daekningsType != DaekningsType.DAEKNING_IKKEDAEKKET) {
158 continue;
159 }
160
161 if (addr.distributor != null && addr.distributor.equals("LUKKET")) {
162 continue;
163 }
164
165
166 HundredePctBean bean = hundredePct.get(addr.postnr);
167 if (bean == null) {
168 continue;
169 }
170
171 addr.daekningsType = DaekningsType.DAEKNING_100PCT;
172 addr.rute = bean.rute;
173 addr.koreliste = bean.koreliste;
174 addr.dbkBane = bean.dbkBane;
175 addr.distributor = bean.distributor;
176 }
177
178 System.out.println("Build Completed");
179
180 }
181
182
183 private String calculateExtendedRoute(ExtendedBean eb, Address orgAddress, Address targetAddress) {
184 switch (targetAddress.distributor) {
185 case "DAO":
186 // ///////////////////////////////////////////////////////////////////
187 switch( eb.transport) {
188 case "cykel":
189 if (eb.afstand < 0.151) {
190 return "." + targetAddress.rute;
191 } else if (eb.afstand < 0.501) {
192 return ".." + targetAddress.rute;
193 } else if (eb.afstand < 0.701) {
194 return "..." + targetAddress.rute;
195 } else if (eb.afstand < 0.501) {
196 return "...." + targetAddress.rute;
197 }
198 break;
199 case "scooter":
200 if (eb.afstand < 0.151) {
201 return "." + targetAddress.rute;
202 } else if (eb.afstand < 0.801) {
203 return ".." + targetAddress.rute;
204 } else if (eb.afstand < 1.201) {
205 return "..." + targetAddress.rute;
206 } else if (eb.afstand < 2.101) {
207 return "...." + targetAddress.rute;
208 }
209 break;
210 case "bil":
211 if (eb.afstand < 0.151) {
212 return "." + targetAddress.rute;
213 } else if (eb.afstand < 1.001) {
214 return ".." + targetAddress.rute;
215 } else if (eb.afstand < 1.601) {
216 return "..." + targetAddress.rute;
217 } else if (eb.afstand < 2.601) {
218 return "...." + targetAddress.rute;
219 }
220 break;
221 }
222 break;
223
224 ///////////////////////////////////////////////////////////
225
226 case "BK":
227 String inject;
228 if (eb.afstand <= 0.500) {
229 inject = ".";
230 } else {
231 inject = "..";
232 }
233 return AddressUtils.injectIntoBk(targetAddress.rute, inject);
234 }
235 return null;
236 }
237
238
239 }

  ViewVC Help
Powered by ViewVC 1.1.20