Petfinder
Ruby gem wrapper for the Petfinder API.
Installation
Add this line to your application's Gemfile:
gem 'petfinder'
And then execute:
$ bundle
Or install it yourself as:
$ gem install petfinder
Get your API key
Get your Petfinder API key at: http://www.petfinder.com/developers/api-key
Usage
Instantiate a client
petfinder = Petfinder::Client.new('your_api_key', 'your_api_secret')
or configure once
Petfinder.configure do |config|
  config.api_key = 'your_api_key'
  config.api_secret = 'your_api_secret'
end
petfinder = Petfinder::Client.new
Examples
Return a list of dogs in the "90210" zip code
pets = petfinder.find_pets('dog', '90210')
pets.count
# => "25"
pets.first.name
# => "Petey"
pets.first.shelterid
# => "CA123"
Returning paged results
petfinder.find_pets('dog', 77057, count: 25)
# page 2
petfinder.find_pets('dog', 77057, count: 25, offset: 25)
# page 3
petfinder.find_pets('dog', 77057, count: 25, offset: 50)
# page 4
petfinder.find_pets('dog', 77057, count: 25, offset: 75)
Return information about the shelter with id "CA123"
shelter = petfinder.shelter('CA123')
shelter.name
# => "Melrose Place SPCA"
Other available methods
# Valid animal types: barnyard, bird, cat, dog, horse, pig, reptile, smallfurry
breeds = petfinder.breeds(animal_type)
# Options available: animal, breed, size, sex, location, shelterid
pet = petfinder.random_pet()
pet = petfinder.pet(id)
# Options available: breed, size, sex, age, offset, count
pets = petfinder.find_pets(animal_type, location, )
# Options available: status, offset, count
pets = shelter_pets(shelter_id, )
# Options available: name, offset, count
shelters = petfinder.find_shelters(location, )
shelters = petfinder.find_shelters_by_breed(animal_type, breed)
shelter = petfinder.shelter(shelter_id)
TODO
- Implement use of security token when Petfinder requires it
- Support paging for results
Contributing
- Fork it
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create new Pull Request
Copyright
Copyright (c) 2010-2013 Eric Hutzelman. See LICENSE for details.


