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

Diff of /dao/DaoAdresseService/src/dk/daoas/daoadresseservice/GeocodeHelper.java

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 2349 by torben, Mon Feb 23 15:02:48 2015 UTC revision 2367 by torben, Tue Feb 24 12:23:59 2015 UTC
# Line 16  import com.google.gson.Gson; Line 16  import com.google.gson.Gson;
16  import dk.daoas.daoadresseservice.admin.ServiceConfig;  import dk.daoas.daoadresseservice.admin.ServiceConfig;
17  import dk.daoas.daoadresseservice.beans.OSMAddress;  import dk.daoas.daoadresseservice.beans.OSMAddress;
18  import dk.daoas.daoadresseservice.util.HttpUtil;  import dk.daoas.daoadresseservice.util.HttpUtil;
19    import dk.thoerup.circuitbreaker.CircuitBreaker;
20    import dk.thoerup.circuitbreaker.CircuitBreakerManager;
21    import dk.thoerup.circuitbreaker.CircuitInvocation;
22    
23  public class GeocodeHelper {  public class GeocodeHelper {
24                                    
# Line 23  public class GeocodeHelper { Line 26  public class GeocodeHelper {
26    
27          public static void main(String[] args) throws IOException {          public static void main(String[] args) throws IOException {
28                  ServiceConfig conf = new ServiceConfig();                  ServiceConfig conf = new ServiceConfig();
29                    conf.osmTimeout = 1000;
30                                    
31                  int post = 8700;                  int post = 8700;
32                  String vej = "Enebarvej";                  String vej = "Enebarvej";
# Line 32  public class GeocodeHelper { Line 36  public class GeocodeHelper {
36                  long stop1 = System.currentTimeMillis();                  long stop1 = System.currentTimeMillis();
37                                    
38                  long start2 = System.currentTimeMillis();                  long start2 = System.currentTimeMillis();
39                  System.out.println( "OSM:" +  GeocodeHelper.openstreetmapHelper(post, vej) );                  System.out.println( "OSM:" +  GeocodeHelper.openstreetmapHelper(conf, post, vej) );
40                  long stop2 = System.currentTimeMillis();                  long stop2 = System.currentTimeMillis();
41                                    
42                  System.out.println("Google: " + (stop1-start1));                  System.out.println("Google: " + (stop1-start1));
43                  System.out.println("OSM: " + (stop2-start2));                  System.out.println("OSM: " + (stop2-start2));
44          }          }
45                    
46          public static String openstreetmapHelper(int postnr, String vejnavn) {          public static String openstreetmapHelper(ServiceConfig conf, int postnr, String vejnavn) {
47                                    
48                  try {                  try {
49                                    
50                            OSMInvocation wrapper = new OSMInvocation( conf, postnr, vejnavn );
51                            CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("osm");
52    
53                            return (String) breaker.invoke(wrapper);
54    
55                            
56                    } catch (Exception e) {
57                            System.out.println( "OSMError: " + e.getClass().getName() +" / "+ e.getMessage() );
58                    }                                                              
59                    return null;
60            }
61            
62            
63            
64            public static String googleHelper(ServiceConfig conf, int postnr, String vejnavn) {
65                    try {
66                            GoogleInvocation wrapper = new GoogleInvocation( conf, postnr, vejnavn );
67                            CircuitBreaker breaker = CircuitBreakerManager.getManager().getCircuitBreaker("google");
68    
69                            return (String) breaker.invoke(wrapper);
70                            
71                    } catch (Exception e) {
72                            System.out.println( "GoogleError: " + e.getClass().getName() +" / "+ e.getMessage() );
73                    }
74                    return null;    
75            }
76            
77    
78            public static class OSMInvocation implements CircuitInvocation {
79                    int postnr;
80                    String vejnavn;
81                    ServiceConfig conf;
82                    
83                    public OSMInvocation(ServiceConfig conf, int postnr, String vejnavn) {
84                            this.conf = conf;
85                            this.postnr= postnr;
86                            this.vejnavn = vejnavn;                
87                    }
88                    
89                    @Override
90                    public String proceed() throws Exception {
91                            //TimingHelper timer = new TimingHelper();
92                          String encVej = URLEncoder.encode(vejnavn, "UTF-8");                          String encVej = URLEncoder.encode(vejnavn, "UTF-8");
93                                                    
94                          String url = "http://nominatim.openstreetmap.org/search?country=DK&street=" + encVej + "&postalcode=" + postnr + "&format=json&addressdetails=1";                          String url = "http://nominatim.openstreetmap.org/search?country=DK&street=" + encVej + "&postalcode=" + postnr + "&format=json&addressdetails=1";
95                          //String url = "http://nominatim.openstreetmap.org/search?country=DK&street=" + encVej + "&format=json&addressdetails=1";                          //String url = "http://nominatim.openstreetmap.org/search?country=DK&street=" + encVej + "&format=json&addressdetails=1";
96                          //System.out.println (url);                          //System.out.println (url);
97                                                    
98                          String json = HttpUtil.getContentString(url, 1000);                          String json = HttpUtil.getContentString(url, conf.osmTimeout);
99                          //System.out.println(json);                          //System.out.println(json);
100                                                    
101                          Gson gson = new Gson();                          Gson gson = new Gson();
102                          OSMAddress adrList[] = gson.fromJson(json, OSMAddress[].class);                          OSMAddress adrList[] = gson.fromJson(json, OSMAddress[].class);
103                                                    
104                            //timer.printElapsed("OSM elapsed");
105                            
106                          //System.out.println("Count: " + adrList.length);                          //System.out.println("Count: " + adrList.length);
107                          if (adrList.length != 1)                          if (adrList.length != 1)
108                                  return null;                                  return null;
# Line 63  public class GeocodeHelper { Line 111  public class GeocodeHelper {
111                                  return adrList[0].address.road;                                  return adrList[0].address.road;
112                          }                          }
113    
114                                                    return null;
115                  } catch (Exception e) {                  }
                         System.out.println( "Error: " + e.getMessage() );  
                 }                                                                
                 return null;  
116          }          }
117                    
118                    
119                    public static class GoogleInvocation implements CircuitInvocation {
120          public static String googleHelper(ServiceConfig conf, int postnr, String vejnavn) {                  ServiceConfig conf;
121                  try {                  int postnr;
122                          //Todo: Load api key from context config                  String vejnavn;
123                    
124                    public GoogleInvocation(ServiceConfig conf, int postnr, String vejnavn) {
125                            this.conf = conf;
126                            this.postnr= postnr;
127                            this.vejnavn = vejnavn;
128                            
129                    }
130    
131                    @Override
132                    public String proceed() throws Exception {
133                            
134                          final Geocoder geocoder;                          final Geocoder geocoder;
135                          if ( conf.googleApiKey != null ) {                          if ( conf.googleApiKey != null ) {
136                                  geocoder = new Geocoder(conf.googleApiUser, conf.googleApiKey); //Throws InvalidKeyException                                  geocoder = new Geocoder(conf.googleApiUser, conf.googleApiKey); //Throws InvalidKeyException
137                          } else {                          } else {
138                                  geocoder = new Geocoder();                                  geocoder = new Geocoder();
139                          }                          }
140                                                    //TimingHelper timer = new TimingHelper();
141                                                    
142                          String search = vejnavn + ", " + postnr + ", Denmark";                          String search = vejnavn + ", " + postnr + ", Denmark";
143                          GeocoderRequest geocoderRequest = new GeocoderRequestBuilder().setAddress(search).setLanguage("en").getGeocoderRequest();                          GeocoderRequest geocoderRequest = new GeocoderRequestBuilder().setAddress(search).setLanguage("en").getGeocoderRequest();
144                          GeocodeResponse geocoderResponse = geocoder.geocode(geocoderRequest);                          GeocodeResponse geocoderResponse = geocoder.geocode(geocoderRequest);
145                                                            
146                            //timer.printElapsed("Google elapsed");
147                                                    
148                          //System.out.println( "Status: >" + geocoderResponse.getStatus() + "<");                          //System.out.println( "Status: >" + geocoderResponse.getStatus() + "<");
149                          if (  geocoderResponse.getStatus() != GeocoderStatus.OK) {                          if (  geocoderResponse.getStatus() != GeocoderStatus.OK) {                              
150                                  System.out.println("Google responded with " + geocoderResponse.getStatus() );                                  
151                                  return null;                                  if (geocoderResponse.getStatus() == GeocoderStatus.ZERO_RESULTS) {
152                                            return null;
153                                    } else {
154                                            System.out.println("Google responded with " + geocoderResponse.getStatus() );
155                                            //Hvis det er alvorlige fejl skal vi afbryde med exception og trigger circuitbreakeren
156                                            throw new Exception("Google responded with " + geocoderResponse.getStatus() );
157                                    }
158                                    
159                          }                          }
160                                                    
161                          List<GeocoderResult> resList = geocoderResponse.getResults();                          List<GeocoderResult> resList = geocoderResponse.getResults();
# Line 109  public class GeocodeHelper { Line 173  public class GeocodeHelper {
173                                          return c.getLongName();                                          return c.getLongName();
174                                  }                                  }
175                          }                          }
176                                                    return null;
                 } catch (Exception e) {  
                         System.out.println( "GoogleError: " + e.getMessage() );  
177                  }                  }
                 return null;  
178                                    
179          }          }
180    

Legend:
Removed from v.2349  
changed lines
  Added in v.2367

  ViewVC Help
Powered by ViewVC 1.1.20