yellow_api 0.0.1 → 0.0.2
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.
- data/README.md +29 -4
- data/lib/yellow_api/client/get_business_details.rb +41 -2
- data/lib/yellow_api/version.rb +1 -1
- data/spec/fixtures/get_type_ahead.json +1 -0
- data/spec/yellow_api/get_type_ahead_spec.rb +28 -0
- data/yellow_api.gemspec +1 -0
- metadata +40 -25
data/README.md
CHANGED
@@ -1,14 +1,39 @@
|
|
1
1
|
# Yellow API
|
2
2
|
|
3
|
-
Ruby wrapper for the YellowPages'
|
3
|
+
Ruby wrapper for the YellowPages' [YellowAPI](http://www.yellowapi.com).
|
4
4
|
|
5
5
|
## Installation
|
6
|
-
gem install
|
6
|
+
gem install yellow_api
|
7
|
+
|
8
|
+
## Examples
|
9
|
+
|
10
|
+
require 'yellow_api'
|
11
|
+
|
12
|
+
# Creating a client
|
13
|
+
@client = YellowApi.new(:apikey => "yourapikeygoeshere")
|
14
|
+
|
15
|
+
@client = YellowApi.new(:apikey => "sandboxapikey", :sandbox_enabled => true)
|
16
|
+
|
17
|
+
# Find businesses by listing
|
18
|
+
@client.find_business("barber", "Ottawa")
|
19
|
+
|
20
|
+
@client.find_business("barber", "Ottawa", { :pgLen => 10 }) # Limit to 10
|
21
|
+
|
22
|
+
# Get business details
|
23
|
+
my_barber = @client.find_business("barber", "Ottawa").listings.first
|
24
|
+
@client.get_business_details("Ontario", my_barber.name, my_barber.listingId)
|
25
|
+
|
26
|
+
# Find dealers
|
27
|
+
@client.find_dealer(6418182, { :pgLen => 10 })
|
28
|
+
|
29
|
+
# Get type ahead
|
30
|
+
@client.get_type_ahead("auto", :what)
|
31
|
+
@client.get_type_ahead("monct", :where)
|
7
32
|
|
8
33
|
## Documentation
|
9
|
-
[See here](http://rdoc.info/
|
34
|
+
[See here](http://rdoc.info/github/ianbishop/yellow_api/master/YellowApi)
|
10
35
|
|
11
|
-
|
36
|
+
[Official API docs](http://www.yellowapi.com/docs/places)
|
12
37
|
|
13
38
|
## Inspiration
|
14
39
|
API style was largely stolen/inspired by [hacker_news_search](https://github.com/ryanatwork/hacker_news_search) and [twitter](https://github.com/jnunemaker/twitter).
|
@@ -1,7 +1,25 @@
|
|
1
|
+
require 'active_support/all'
|
2
|
+
|
1
3
|
module YellowApi
|
2
4
|
class Client
|
3
5
|
module GetBusinessDetails
|
4
6
|
|
7
|
+
PROVINCE_ABBREVIATION_MAP = {
|
8
|
+
:ab => "Alberta",
|
9
|
+
:bc => "British-Columbia",
|
10
|
+
:mb => "Manitoba",
|
11
|
+
:nb => "New-Brunswick",
|
12
|
+
:nl => "Newfoundland-and-Labrador",
|
13
|
+
:nt => "Northwest-Territories",
|
14
|
+
:ns => "Nova-Scotia",
|
15
|
+
:nu => "Nunavut",
|
16
|
+
:on => "Ontario",
|
17
|
+
:pe => "Prince-Edward-Island",
|
18
|
+
:qc => "Quebec",
|
19
|
+
:sk => "Saskatchewan",
|
20
|
+
:yt => "Yukon"
|
21
|
+
}
|
22
|
+
|
5
23
|
# Gets business details.
|
6
24
|
#
|
7
25
|
# @see http://www.yellowapi.com/docs/places/#getbusinessdetails
|
@@ -20,13 +38,34 @@ module YellowApi
|
|
20
38
|
# @example
|
21
39
|
# YellowApi.get_business_details("Ile-du-Prince-Edouard", "Co-operators-The", 6418182)
|
22
40
|
def get_business_details(province, business_name, listing_id, options={})
|
23
|
-
options[:prov] = province
|
24
|
-
options["bus-name"] = business_name
|
41
|
+
options[:prov] = normalize(expand_province(province))
|
42
|
+
options["bus-name"] = normalize(business_name)
|
25
43
|
options[:listingId] = listing_id
|
44
|
+
options[:city] = normalize(options[:city]) if options.has_key? :city
|
26
45
|
|
27
46
|
get('/GetBusinessDetails/', options)
|
28
47
|
end
|
29
48
|
|
49
|
+
# Normalizes a given string
|
50
|
+
#
|
51
|
+
# All accents are removed (i.e. ‘à’ becomes ‘a’),
|
52
|
+
# and All non-alphanumeric characters are replaced by dash “-”, and
|
53
|
+
# Multiple dashes are replaced by a single dash.
|
54
|
+
#
|
55
|
+
# @see http://www.yellowapi.com/docs/places/#getbusinessdetails
|
56
|
+
# @see http://stackoverflow.com/questions/225471/how-do-i-replace-accented-latin-characters-in-ruby
|
57
|
+
def normalize(s)
|
58
|
+
s.mb_chars.normalize(:kd).gsub(/[^\x00-\x7F]/n, '').to_s
|
59
|
+
.gsub(/[\W]/, '-').gsub(/-+/, '-')
|
60
|
+
end
|
61
|
+
|
62
|
+
# Expands an abbreviated province
|
63
|
+
#
|
64
|
+
# This handles the fact that FindBusiness returns abbreviated provinces codes
|
65
|
+
# yet expects full province names for GetBusinessDetails
|
66
|
+
def expand_province(prov)
|
67
|
+
PROVINCE_ABBREVIATION_MAP.fetch(prov.downcase.to_sym, prov)
|
68
|
+
end
|
30
69
|
end
|
31
70
|
end
|
32
71
|
end
|
data/lib/yellow_api/version.rb
CHANGED
@@ -0,0 +1 @@
|
|
1
|
+
[{"value":"auto body shop"},{"value":"automobile wrecking & recycling"},{"value":"automobile repair"},{"value":"automobile dealers"},{"value":"automobile dealers-new cars"},{"value":"automobile dealers-used cars"},{"value":"automobile parts"},{"value":"automobile detailing"},{"value":"automobiles"},{"value":"automobile insurance"}]
|
@@ -0,0 +1,28 @@
|
|
1
|
+
require 'helper'
|
2
|
+
|
3
|
+
describe YellowApi::Client::GetTypeAhead do
|
4
|
+
|
5
|
+
before do
|
6
|
+
@client = YellowApi::Client.new(:apikey => "a1s2d3f4g5h6j7k8l9k6j5j4")
|
7
|
+
end
|
8
|
+
|
9
|
+
describe ".get_type_ahead" do
|
10
|
+
before do
|
11
|
+
WebMock.allow_net_connect!
|
12
|
+
|
13
|
+
stub_get("GetTypeAhead/?apikey=a1s2d3f4g5h6j7k8l9k6j5j4&text=au&field=WHAT&UID=1").
|
14
|
+
to_return(:status => 200, :body => fixture("get_type_ahead.json"))
|
15
|
+
end
|
16
|
+
|
17
|
+
it "should return suggestions" do
|
18
|
+
wait 2 do
|
19
|
+
suggestions = @client.get_type_ahead("au", :what)
|
20
|
+
|
21
|
+
a_get("GetTypeAhead/?apikey=a1s2d3f4g5h6j7k8l9k6j5j4&text=au&field=WHAT&lang=en&fmt=JSON&UID=#{@client.uid}").
|
22
|
+
should have_been_made
|
23
|
+
|
24
|
+
suggestions.length.should > 0
|
25
|
+
end
|
26
|
+
end
|
27
|
+
end
|
28
|
+
end
|
data/yellow_api.gemspec
CHANGED
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: yellow_api
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.0.
|
4
|
+
version: 0.0.2
|
5
5
|
prerelease:
|
6
6
|
platform: ruby
|
7
7
|
authors:
|
@@ -13,7 +13,7 @@ date: 2012-04-06 00:00:00.000000000 Z
|
|
13
13
|
dependencies:
|
14
14
|
- !ruby/object:Gem::Dependency
|
15
15
|
name: maruku
|
16
|
-
requirement: &
|
16
|
+
requirement: &72188980 !ruby/object:Gem::Requirement
|
17
17
|
none: false
|
18
18
|
requirements:
|
19
19
|
- - ~>
|
@@ -21,10 +21,10 @@ dependencies:
|
|
21
21
|
version: '0.6'
|
22
22
|
type: :development
|
23
23
|
prerelease: false
|
24
|
-
version_requirements: *
|
24
|
+
version_requirements: *72188980
|
25
25
|
- !ruby/object:Gem::Dependency
|
26
26
|
name: rake
|
27
|
-
requirement: &
|
27
|
+
requirement: &72188360 !ruby/object:Gem::Requirement
|
28
28
|
none: false
|
29
29
|
requirements:
|
30
30
|
- - ~>
|
@@ -32,10 +32,10 @@ dependencies:
|
|
32
32
|
version: '0.9'
|
33
33
|
type: :development
|
34
34
|
prerelease: false
|
35
|
-
version_requirements: *
|
35
|
+
version_requirements: *72188360
|
36
36
|
- !ruby/object:Gem::Dependency
|
37
37
|
name: rspec
|
38
|
-
requirement: &
|
38
|
+
requirement: &72187120 !ruby/object:Gem::Requirement
|
39
39
|
none: false
|
40
40
|
requirements:
|
41
41
|
- - ~>
|
@@ -43,10 +43,10 @@ dependencies:
|
|
43
43
|
version: '2.6'
|
44
44
|
type: :development
|
45
45
|
prerelease: false
|
46
|
-
version_requirements: *
|
46
|
+
version_requirements: *72187120
|
47
47
|
- !ruby/object:Gem::Dependency
|
48
48
|
name: simplecov
|
49
|
-
requirement: &
|
49
|
+
requirement: &72186590 !ruby/object:Gem::Requirement
|
50
50
|
none: false
|
51
51
|
requirements:
|
52
52
|
- - ~>
|
@@ -54,10 +54,10 @@ dependencies:
|
|
54
54
|
version: 0.5.3
|
55
55
|
type: :development
|
56
56
|
prerelease: false
|
57
|
-
version_requirements: *
|
57
|
+
version_requirements: *72186590
|
58
58
|
- !ruby/object:Gem::Dependency
|
59
59
|
name: webmock
|
60
|
-
requirement: &
|
60
|
+
requirement: &72185860 !ruby/object:Gem::Requirement
|
61
61
|
none: false
|
62
62
|
requirements:
|
63
63
|
- - ~>
|
@@ -65,10 +65,10 @@ dependencies:
|
|
65
65
|
version: 1.7.6
|
66
66
|
type: :development
|
67
67
|
prerelease: false
|
68
|
-
version_requirements: *
|
68
|
+
version_requirements: *72185860
|
69
69
|
- !ruby/object:Gem::Dependency
|
70
70
|
name: yard
|
71
|
-
requirement: &
|
71
|
+
requirement: &72185320 !ruby/object:Gem::Requirement
|
72
72
|
none: false
|
73
73
|
requirements:
|
74
74
|
- - ~>
|
@@ -76,10 +76,10 @@ dependencies:
|
|
76
76
|
version: '0.7'
|
77
77
|
type: :development
|
78
78
|
prerelease: false
|
79
|
-
version_requirements: *
|
79
|
+
version_requirements: *72185320
|
80
80
|
- !ruby/object:Gem::Dependency
|
81
81
|
name: faraday
|
82
|
-
requirement: &
|
82
|
+
requirement: &72184950 !ruby/object:Gem::Requirement
|
83
83
|
none: false
|
84
84
|
requirements:
|
85
85
|
- - ~>
|
@@ -87,10 +87,10 @@ dependencies:
|
|
87
87
|
version: 0.7.4
|
88
88
|
type: :runtime
|
89
89
|
prerelease: false
|
90
|
-
version_requirements: *
|
90
|
+
version_requirements: *72184950
|
91
91
|
- !ruby/object:Gem::Dependency
|
92
92
|
name: faraday_middleware
|
93
|
-
requirement: &
|
93
|
+
requirement: &72184420 !ruby/object:Gem::Requirement
|
94
94
|
none: false
|
95
95
|
requirements:
|
96
96
|
- - ~>
|
@@ -98,10 +98,10 @@ dependencies:
|
|
98
98
|
version: 0.7.0
|
99
99
|
type: :runtime
|
100
100
|
prerelease: false
|
101
|
-
version_requirements: *
|
101
|
+
version_requirements: *72184420
|
102
102
|
- !ruby/object:Gem::Dependency
|
103
103
|
name: hashie
|
104
|
-
requirement: &
|
104
|
+
requirement: &72252170 !ruby/object:Gem::Requirement
|
105
105
|
none: false
|
106
106
|
requirements:
|
107
107
|
- - ~>
|
@@ -109,10 +109,10 @@ dependencies:
|
|
109
109
|
version: 1.2.0
|
110
110
|
type: :runtime
|
111
111
|
prerelease: false
|
112
|
-
version_requirements: *
|
112
|
+
version_requirements: *72252170
|
113
113
|
- !ruby/object:Gem::Dependency
|
114
114
|
name: multi_json
|
115
|
-
requirement: &
|
115
|
+
requirement: &72251260 !ruby/object:Gem::Requirement
|
116
116
|
none: false
|
117
117
|
requirements:
|
118
118
|
- - ~>
|
@@ -120,10 +120,10 @@ dependencies:
|
|
120
120
|
version: 1.0.2
|
121
121
|
type: :runtime
|
122
122
|
prerelease: false
|
123
|
-
version_requirements: *
|
123
|
+
version_requirements: *72251260
|
124
124
|
- !ruby/object:Gem::Dependency
|
125
125
|
name: rash
|
126
|
-
requirement: &
|
126
|
+
requirement: &72250510 !ruby/object:Gem::Requirement
|
127
127
|
none: false
|
128
128
|
requirements:
|
129
129
|
- - ~>
|
@@ -131,10 +131,10 @@ dependencies:
|
|
131
131
|
version: 0.3.0
|
132
132
|
type: :runtime
|
133
133
|
prerelease: false
|
134
|
-
version_requirements: *
|
134
|
+
version_requirements: *72250510
|
135
135
|
- !ruby/object:Gem::Dependency
|
136
136
|
name: uuid
|
137
|
-
requirement: &
|
137
|
+
requirement: &72249390 !ruby/object:Gem::Requirement
|
138
138
|
none: false
|
139
139
|
requirements:
|
140
140
|
- - ~>
|
@@ -142,7 +142,18 @@ dependencies:
|
|
142
142
|
version: 2.3.5
|
143
143
|
type: :runtime
|
144
144
|
prerelease: false
|
145
|
-
version_requirements: *
|
145
|
+
version_requirements: *72249390
|
146
|
+
- !ruby/object:Gem::Dependency
|
147
|
+
name: activesupport
|
148
|
+
requirement: &72248400 !ruby/object:Gem::Requirement
|
149
|
+
none: false
|
150
|
+
requirements:
|
151
|
+
- - ~>
|
152
|
+
- !ruby/object:Gem::Version
|
153
|
+
version: 3.2.3
|
154
|
+
type: :runtime
|
155
|
+
prerelease: false
|
156
|
+
version_requirements: *72248400
|
146
157
|
description: Simple ruby wrapper for the YellowPages' Yellow API
|
147
158
|
email: ian.bishop@unb.ca
|
148
159
|
executables: []
|
@@ -168,11 +179,13 @@ files:
|
|
168
179
|
- spec/fixtures/find_business.json
|
169
180
|
- spec/fixtures/find_dealer.json
|
170
181
|
- spec/fixtures/get_business_details.json
|
182
|
+
- spec/fixtures/get_type_ahead.json
|
171
183
|
- spec/helper.rb
|
172
184
|
- spec/yellow_api/client_spec.rb
|
173
185
|
- spec/yellow_api/find_business_spec.rb
|
174
186
|
- spec/yellow_api/find_dealer_spec.rb
|
175
187
|
- spec/yellow_api/get_business_details_spec.rb
|
188
|
+
- spec/yellow_api/get_type_ahead_spec.rb
|
176
189
|
- spec/yellow_api_spec.rb
|
177
190
|
- yellow_api.gemspec
|
178
191
|
homepage: https://github.com/ianbishop/yellow_api
|
@@ -203,10 +216,12 @@ test_files:
|
|
203
216
|
- spec/fixtures/find_business.json
|
204
217
|
- spec/fixtures/find_dealer.json
|
205
218
|
- spec/fixtures/get_business_details.json
|
219
|
+
- spec/fixtures/get_type_ahead.json
|
206
220
|
- spec/helper.rb
|
207
221
|
- spec/yellow_api/client_spec.rb
|
208
222
|
- spec/yellow_api/find_business_spec.rb
|
209
223
|
- spec/yellow_api/find_dealer_spec.rb
|
210
224
|
- spec/yellow_api/get_business_details_spec.rb
|
225
|
+
- spec/yellow_api/get_type_ahead_spec.rb
|
211
226
|
- spec/yellow_api_spec.rb
|
212
227
|
has_rdoc:
|