require File.dirname(__FILE__) + '/../lib/yelp4r'
# Read the Yelp API Documentation
# http://www.yelp.com/developers/documentation
# Initialize a new Yelp Client
client = Yelp4r::Client.new('your_ywsid_key')
# Initialize a new Phone Search object
phone_search = Yelp4r::PhoneSearch.new(client)
# Phone search only does one thing, looks up a business by a phone number
results = phone_search.search_by_phone_number('1234567890')
# A response object is returned
# The response is either a Mash Object or an array of Mash objects, these are hashes that have been converted into OpenStruct-esque objects
# Also all keys have been rubyified, eg: results.body['camelCase] is now results.body.camel_case
# The following response methods are available to all Yelp searches in the 3 search classes
# PhoneSearch, ReveiwSearch, NeighborhoodSearch
if results.success?
puts results.data # Pure data of the repsonse
puts results.body # Entire body of the response
else
puts results.reponse_code # Yelp repsonse code
puts results.error_message # The text of the error message
end
# Initialize a Neighborhood Search Object
neigh_search = Yelp4r::NeighborhoodSearch.new(client)
# Search by a geocode point
# Pass a Lat and Long respectively
results = neigh_search.search_by_geocode(37.788022, -122.399797)
# Search by a location (with optional country code)
results = neigh_search.search_by_location('Boston, MA')
# or
results = neigh_search.search_by_location('Boston, MA', 'US')
# Again the response methods above apply here as well
# Initialize a Review Search Object
review_search = Yelp4r::ReviewSearch.new(client)
# Each search method for the review_search object takes the following optional parameters
# :category => this is a Yelp category term (see the categories list below)
# :term => this is a search term
# :num_biz_requested => a number 1 through 20 (default is 10)
# Search by a bouding box
# Pass a top left lat/long and bottom right lat/long
results = review_search.search_by_bounding_box(38, -122.6, 37.788022, -122.399797)
results = review_search.search_by_bounding_box(38, -122.6, 37.788022, -122.399797, :term => "bars", :num_biz_requested => 15)
# Search by geocode and radius
# This method accepts and optional param of
# :radius => max of 25
results = review_search.search_by_geocode_and_radius(37.788022, -122.399797)
results = review_search.search_by_geocode_and_radius(37.788022, -122.399797, :radius => .5)
results = review_search.search_by_geocode_and_radius(37.788022, -122.399797, :category => "bars", :radius => 1)
# Search by location
# This method accepts and optional params of:
# :radius => max of 25
# :cc => country code
results = review_search.search_by_location('Boston, MA')
results = review_search.search_by_location('Boston, MA', :num_biz_requested => 10)
results = review_search.search_by_location('Boston, MA', :radius => 5)
results = review_search.search_by_location('Boston, MA', :term => "doctors")
# Again the response methods above apply here as well
# Yelp4r provides a couple of html parsed lists powered by Hpricot
# This first is the list of neighborhoods
# see the page here: http://www.yelp.com/developers/documentation/neighborhood_list
# Create a new Neighborhoods object
neighborhoods = Yelp4r::Neighborhoods.new
# Get the list
# This list is designed to keep the parent and its children in a hash with the parent being the key and the children in an array
# which is generated by a recursive function
# see the spec_helper method yelp4r_test_neighs_list for an example.
puts neighborhoods.list
# There is also a method to return a list of