geocoder 1.5.2 → 1.6.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +26 -0
  3. data/LICENSE +1 -1
  4. data/README.md +8 -10
  5. data/bin/console +13 -0
  6. data/examples/autoexpire_cache_redis.rb +2 -0
  7. data/lib/easting_northing.rb +171 -0
  8. data/lib/geocoder/configuration.rb +2 -1
  9. data/lib/geocoder/configuration_hash.rb +4 -4
  10. data/lib/geocoder/ip_address.rb +2 -1
  11. data/lib/geocoder/lookup.rb +6 -3
  12. data/lib/geocoder/lookups/ban_data_gouv_fr.rb +14 -1
  13. data/lib/geocoder/lookups/esri.rb +6 -0
  14. data/lib/geocoder/lookups/geocodio.rb +1 -1
  15. data/lib/geocoder/lookups/google.rb +7 -2
  16. data/lib/geocoder/lookups/google_places_details.rb +8 -14
  17. data/lib/geocoder/lookups/google_places_search.rb +28 -2
  18. data/lib/geocoder/lookups/google_premier.rb +4 -0
  19. data/lib/geocoder/lookups/here.rb +7 -16
  20. data/lib/geocoder/lookups/ip2location.rb +5 -13
  21. data/lib/geocoder/lookups/ipgeolocation.rb +51 -0
  22. data/lib/geocoder/lookups/latlon.rb +1 -2
  23. data/lib/geocoder/lookups/nationaal_georegister_nl.rb +38 -0
  24. data/lib/geocoder/lookups/osmnames.rb +57 -0
  25. data/lib/geocoder/lookups/pickpoint.rb +1 -1
  26. data/lib/geocoder/lookups/smarty_streets.rb +6 -1
  27. data/lib/geocoder/lookups/telize.rb +1 -1
  28. data/lib/geocoder/lookups/tencent.rb +9 -9
  29. data/lib/geocoder/lookups/uk_ordnance_survey_names.rb +59 -0
  30. data/lib/geocoder/lookups/yandex.rb +1 -2
  31. data/lib/geocoder/results/baidu.rb +0 -4
  32. data/lib/geocoder/results/ban_data_gouv_fr.rb +1 -1
  33. data/lib/geocoder/results/db_ip_com.rb +1 -1
  34. data/lib/geocoder/results/ipgeolocation.rb +59 -0
  35. data/lib/geocoder/results/nationaal_georegister_nl.rb +62 -0
  36. data/lib/geocoder/results/nominatim.rb +4 -0
  37. data/lib/geocoder/results/osmnames.rb +56 -0
  38. data/lib/geocoder/results/uk_ordnance_survey_names.rb +59 -0
  39. data/lib/geocoder/results/yandex.rb +217 -59
  40. data/lib/geocoder/sql.rb +4 -4
  41. data/lib/geocoder/util.rb +29 -0
  42. data/lib/geocoder/version.rb +1 -1
  43. data/lib/maxmind_database.rb +3 -3
  44. metadata +17 -11
  45. data/lib/geocoder/lookups/geocoder_us.rb +0 -51
  46. data/lib/geocoder/results/geocoder_us.rb +0 -39
  47. data/lib/hash_recursive_merge.rb +0 -74
@@ -44,13 +44,13 @@ module Geocoder
44
44
  end
45
45
 
46
46
  def within_bounding_box(sw_lat, sw_lng, ne_lat, ne_lng, lat_attr, lon_attr)
47
- spans = "#{lat_attr} BETWEEN #{sw_lat} AND #{ne_lat} AND "
47
+ spans = "#{lat_attr} BETWEEN #{sw_lat.to_f} AND #{ne_lat.to_f} AND "
48
48
  # handle box that spans 180 longitude
49
49
  if sw_lng.to_f > ne_lng.to_f
50
- spans + "(#{lon_attr} BETWEEN #{sw_lng} AND 180 OR " +
51
- "#{lon_attr} BETWEEN -180 AND #{ne_lng})"
50
+ spans + "(#{lon_attr} BETWEEN #{sw_lng.to_f} AND 180 OR " +
51
+ "#{lon_attr} BETWEEN -180 AND #{ne_lng.to_f})"
52
52
  else
53
- spans + "#{lon_attr} BETWEEN #{sw_lng} AND #{ne_lng}"
53
+ spans + "#{lon_attr} BETWEEN #{sw_lng.to_f} AND #{ne_lng.to_f}"
54
54
  end
55
55
  end
56
56
 
@@ -0,0 +1,29 @@
1
+ # frozen_string_literal: true
2
+
3
+ module Geocoder
4
+ module Util
5
+ #
6
+ # Recursive version of Hash#merge!
7
+ #
8
+ # Adds the contents of +h2+ to +h1+,
9
+ # merging entries in +h1+ with duplicate keys with those from +h2+.
10
+ #
11
+ # Compared with Hash#merge!, this method supports nested hashes.
12
+ # When both +h1+ and +h2+ contains an entry with the same key,
13
+ # it merges and returns the values from both hashes.
14
+ #
15
+ # h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
16
+ # h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
17
+ # recursive_hash_merge(h1, h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
18
+ #
19
+ # Simply using Hash#merge! would return
20
+ #
21
+ # h1.merge!(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
22
+ #
23
+ def self.recursive_hash_merge(h1, h2)
24
+ h1.merge!(h2) do |_key, oldval, newval|
25
+ oldval.class == h1.class ? self.recursive_hash_merge(oldval, newval) : newval
26
+ end
27
+ end
28
+ end
29
+ end
@@ -1,3 +1,3 @@
1
1
  module Geocoder
2
- VERSION = "1.5.2"
2
+ VERSION = "1.6.4"
3
3
  end
@@ -96,9 +96,9 @@ module Geocoder
96
96
 
97
97
  def archive_url_path(package)
98
98
  {
99
- geolite_country_csv: "GeoIPCountryCSV.zip",
100
- geolite_city_csv: "GeoLiteCity_CSV/GeoLiteCity-latest.zip",
101
- geolite_asn_csv: "asnum/GeoIPASNum2.zip"
99
+ geolite_country_csv: "GeoLite2-Country-CSV.zip",
100
+ geolite_city_csv: "GeoLite2-City-CSV.zip",
101
+ geolite_asn_csv: "GeoLite2-ASN-CSV.zip"
102
102
  }[package]
103
103
  end
104
104
 
metadata CHANGED
@@ -1,19 +1,18 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: geocoder
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.5.2
4
+ version: 1.6.4
5
5
  platform: ruby
6
6
  authors:
7
7
  - Alex Reisner
8
8
  autorequire:
9
9
  bindir: bin
10
10
  cert_chain: []
11
- date: 2019-10-03 00:00:00.000000000 Z
11
+ date: 2020-10-06 00:00:00.000000000 Z
12
12
  dependencies: []
13
- description: Provides object geocoding (by street or IP address), reverse geocoding
14
- (coordinates to street address), distance queries for ActiveRecord and Mongoid,
15
- result caching, and more. Designed for Rails but works with Sinatra and other Rack
16
- frameworks too.
13
+ description: Object geocoding (by street or IP address), reverse geocoding (coordinates
14
+ to street address), distance queries for ActiveRecord and Mongoid, result caching,
15
+ and more. Designed for Rails but works with Sinatra and other Rack frameworks too.
17
16
  email:
18
17
  - alex@alexreisner.com
19
18
  executables:
@@ -24,11 +23,13 @@ files:
24
23
  - CHANGELOG.md
25
24
  - LICENSE
26
25
  - README.md
26
+ - bin/console
27
27
  - bin/geocode
28
28
  - examples/autoexpire_cache_dalli.rb
29
29
  - examples/autoexpire_cache_redis.rb
30
30
  - examples/cache_bypass.rb
31
31
  - examples/reverse_geocode_job.rb
32
+ - lib/easting_northing.rb
32
33
  - lib/generators/geocoder/config/config_generator.rb
33
34
  - lib/generators/geocoder/config/templates/initializer.rb
34
35
  - lib/generators/geocoder/maxmind/geolite_city_generator.rb
@@ -59,7 +60,6 @@ files:
59
60
  - lib/geocoder/lookups/esri.rb
60
61
  - lib/geocoder/lookups/freegeoip.rb
61
62
  - lib/geocoder/lookups/geocoder_ca.rb
62
- - lib/geocoder/lookups/geocoder_us.rb
63
63
  - lib/geocoder/lookups/geocodio.rb
64
64
  - lib/geocoder/lookups/geoip2.rb
65
65
  - lib/geocoder/lookups/geoportail_lu.rb
@@ -71,6 +71,7 @@ files:
71
71
  - lib/geocoder/lookups/ip2location.rb
72
72
  - lib/geocoder/lookups/ipapi_com.rb
73
73
  - lib/geocoder/lookups/ipdata_co.rb
74
+ - lib/geocoder/lookups/ipgeolocation.rb
74
75
  - lib/geocoder/lookups/ipinfo_io.rb
75
76
  - lib/geocoder/lookups/ipregistry.rb
76
77
  - lib/geocoder/lookups/ipstack.rb
@@ -81,8 +82,10 @@ files:
81
82
  - lib/geocoder/lookups/maxmind.rb
82
83
  - lib/geocoder/lookups/maxmind_geoip2.rb
83
84
  - lib/geocoder/lookups/maxmind_local.rb
85
+ - lib/geocoder/lookups/nationaal_georegister_nl.rb
84
86
  - lib/geocoder/lookups/nominatim.rb
85
87
  - lib/geocoder/lookups/opencagedata.rb
88
+ - lib/geocoder/lookups/osmnames.rb
86
89
  - lib/geocoder/lookups/pelias.rb
87
90
  - lib/geocoder/lookups/pickpoint.rb
88
91
  - lib/geocoder/lookups/pointpin.rb
@@ -92,6 +95,7 @@ files:
92
95
  - lib/geocoder/lookups/telize.rb
93
96
  - lib/geocoder/lookups/tencent.rb
94
97
  - lib/geocoder/lookups/test.rb
98
+ - lib/geocoder/lookups/uk_ordnance_survey_names.rb
95
99
  - lib/geocoder/lookups/yandex.rb
96
100
  - lib/geocoder/models/active_record.rb
97
101
  - lib/geocoder/models/base.rb
@@ -112,7 +116,6 @@ files:
112
116
  - lib/geocoder/results/esri.rb
113
117
  - lib/geocoder/results/freegeoip.rb
114
118
  - lib/geocoder/results/geocoder_ca.rb
115
- - lib/geocoder/results/geocoder_us.rb
116
119
  - lib/geocoder/results/geocodio.rb
117
120
  - lib/geocoder/results/geoip2.rb
118
121
  - lib/geocoder/results/geoportail_lu.rb
@@ -124,6 +127,7 @@ files:
124
127
  - lib/geocoder/results/ip2location.rb
125
128
  - lib/geocoder/results/ipapi_com.rb
126
129
  - lib/geocoder/results/ipdata_co.rb
130
+ - lib/geocoder/results/ipgeolocation.rb
127
131
  - lib/geocoder/results/ipinfo_io.rb
128
132
  - lib/geocoder/results/ipregistry.rb
129
133
  - lib/geocoder/results/ipstack.rb
@@ -134,8 +138,10 @@ files:
134
138
  - lib/geocoder/results/maxmind.rb
135
139
  - lib/geocoder/results/maxmind_geoip2.rb
136
140
  - lib/geocoder/results/maxmind_local.rb
141
+ - lib/geocoder/results/nationaal_georegister_nl.rb
137
142
  - lib/geocoder/results/nominatim.rb
138
143
  - lib/geocoder/results/opencagedata.rb
144
+ - lib/geocoder/results/osmnames.rb
139
145
  - lib/geocoder/results/pelias.rb
140
146
  - lib/geocoder/results/pickpoint.rb
141
147
  - lib/geocoder/results/pointpin.rb
@@ -145,6 +151,7 @@ files:
145
151
  - lib/geocoder/results/telize.rb
146
152
  - lib/geocoder/results/tencent.rb
147
153
  - lib/geocoder/results/test.rb
154
+ - lib/geocoder/results/uk_ordnance_survey_names.rb
148
155
  - lib/geocoder/results/yandex.rb
149
156
  - lib/geocoder/sql.rb
150
157
  - lib/geocoder/stores/active_record.rb
@@ -152,8 +159,8 @@ files:
152
159
  - lib/geocoder/stores/mongo_base.rb
153
160
  - lib/geocoder/stores/mongo_mapper.rb
154
161
  - lib/geocoder/stores/mongoid.rb
162
+ - lib/geocoder/util.rb
155
163
  - lib/geocoder/version.rb
156
- - lib/hash_recursive_merge.rb
157
164
  - lib/maxmind_database.rb
158
165
  - lib/tasks/geocoder.rake
159
166
  - lib/tasks/maxmind.rake
@@ -178,8 +185,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
178
185
  - !ruby/object:Gem::Version
179
186
  version: '0'
180
187
  requirements: []
181
- rubyforge_project:
182
- rubygems_version: 2.7.6
188
+ rubygems_version: 3.1.2
183
189
  signing_key:
184
190
  specification_version: 4
185
191
  summary: Complete geocoding solution for Ruby.
@@ -1,51 +0,0 @@
1
- require 'geocoder/lookups/base'
2
- require "geocoder/results/geocoder_us"
3
-
4
- module Geocoder::Lookup
5
- class GeocoderUs < Base
6
-
7
- def name
8
- "Geocoder.us"
9
- end
10
-
11
- def supported_protocols
12
- [:http]
13
- end
14
-
15
- private # ----------------------------------------------------------------
16
-
17
- def base_query_url(query)
18
- base_query_url_with_optional_key(configuration.api_key)
19
- end
20
-
21
- def cache_key(query)
22
- base_query_url_with_optional_key(nil) + url_query_string(query)
23
- end
24
-
25
- def base_query_url_with_optional_key(key = nil)
26
- base = "#{protocol}://"
27
- if configuration.api_key
28
- base << "#{configuration.api_key}@"
29
- end
30
- base + "geocoder.us/member/service/csv/geocode?"
31
- end
32
-
33
- def results(query)
34
- return [] unless doc = fetch_data(query)
35
- if doc[0].to_s =~ /^(\d+)\:/
36
- return []
37
- else
38
- return [doc.size == 5 ? ((doc[0..1] << nil) + doc[2..4]) : doc]
39
- end
40
- end
41
-
42
- def query_url_params(query)
43
- (query.text =~ /^\d{5}(?:-\d{4})?$/ ? {:zip => query} : {:address => query.sanitized_text}).merge(super)
44
- end
45
-
46
- def parse_raw_data(raw_data)
47
- raw_data.chomp.split(',')
48
- end
49
- end
50
- end
51
-
@@ -1,39 +0,0 @@
1
- require 'geocoder/results/base'
2
-
3
- module Geocoder::Result
4
- class GeocoderUs < Base
5
- def coordinates
6
- [@data[0].to_f, @data[1].to_f]
7
- end
8
-
9
- def address(format = :full)
10
- "#{street_address}, #{city}, #{state} #{postal_code}, #{country}".sub(/^[ ,]*/, "")
11
- end
12
-
13
- def street_address
14
- @data[2]
15
- end
16
-
17
- def city
18
- @data[3]
19
- end
20
-
21
- def state
22
- @data[4]
23
- end
24
-
25
- alias_method :state_code, :state
26
-
27
- def postal_code
28
- @data[5]
29
- end
30
-
31
- def country
32
- 'United States'
33
- end
34
-
35
- def country_code
36
- 'US'
37
- end
38
- end
39
- end
@@ -1,74 +0,0 @@
1
- #
2
- # = Hash Recursive Merge
3
- #
4
- # Merges a Ruby Hash recursively, Also known as deep merge.
5
- # Recursive version of Hash#merge and Hash#merge!.
6
- #
7
- # Category:: Ruby
8
- # Package:: Hash
9
- # Author:: Simone Carletti <weppos@weppos.net>
10
- # Copyright:: 2007-2008 The Authors
11
- # License:: MIT License
12
- # Link:: http://www.simonecarletti.com/
13
- # Source:: http://gist.github.com/gists/6391/
14
- #
15
- module HashRecursiveMerge
16
-
17
- #
18
- # Recursive version of Hash#merge!
19
- #
20
- # Adds the contents of +other_hash+ to +hsh+,
21
- # merging entries in +hsh+ with duplicate keys with those from +other_hash+.
22
- #
23
- # Compared with Hash#merge!, this method supports nested hashes.
24
- # When both +hsh+ and +other_hash+ contains an entry with the same key,
25
- # it merges and returns the values from both arrays.
26
- #
27
- # h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
28
- # h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
29
- # h1.rmerge!(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
30
- #
31
- # Simply using Hash#merge! would return
32
- #
33
- # h1.merge!(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
34
- #
35
- def rmerge!(other_hash)
36
- merge!(other_hash) do |key, oldval, newval|
37
- oldval.class == self.class ? oldval.rmerge!(newval) : newval
38
- end
39
- end
40
-
41
- #
42
- # Recursive version of Hash#merge
43
- #
44
- # Compared with Hash#merge!, this method supports nested hashes.
45
- # When both +hsh+ and +other_hash+ contains an entry with the same key,
46
- # it merges and returns the values from both arrays.
47
- #
48
- # Compared with Hash#merge, this method provides a different approch
49
- # for merging nasted hashes.
50
- # If the value of a given key is an Hash and both +other_hash+ abd +hsh
51
- # includes the same key, the value is merged instead replaced with
52
- # +other_hash+ value.
53
- #
54
- # h1 = {"a" => 100, "b" => 200, "c" => {"c1" => 12, "c2" => 14}}
55
- # h2 = {"b" => 254, "c" => {"c1" => 16, "c3" => 94}}
56
- # h1.rmerge(h2) #=> {"a" => 100, "b" => 254, "c" => {"c1" => 16, "c2" => 14, "c3" => 94}}
57
- #
58
- # Simply using Hash#merge would return
59
- #
60
- # h1.merge(h2) #=> {"a" => 100, "b" = >254, "c" => {"c1" => 16, "c3" => 94}}
61
- #
62
- def rmerge(other_hash)
63
- r = {}
64
- merge(other_hash) do |key, oldval, newval|
65
- r[key] = oldval.class == self.class ? oldval.rmerge(newval) : newval
66
- end
67
- end
68
-
69
- end
70
-
71
-
72
- class Hash
73
- include HashRecursiveMerge
74
- end