mirror of
https://github.com/jnunemaker/httparty
synced 2023-03-27 23:23:07 -04:00
🎉 Makes http fun again!
config | ||
examples | ||
lib | ||
script | ||
spec | ||
tasks | ||
.gitignore | ||
History.txt | ||
httparty.gemspec | ||
License.txt | ||
Manifest.txt | ||
PostInstall.txt | ||
Rakefile | ||
README.txt | ||
setup.rb |
= httparty == DESCRIPTION: Makes http fun again! == FEATURES/PROBLEMS: * Easy get, post, put, delete requests * Basic http authentication * Default request query string parameters (ie: for api keys that are needed on each request) * Automatic parsing of JSON and XML into ruby hashes == SYNOPSIS: The following is a simple example of wrapping Twitter's API for posting updates. class Twitter include HTTParty base_uri 'twitter.com' basic_auth 'username', 'password' end Twitter.post('/statuses/update.json', :query => {:status => "It's an HTTParty and everyone is invited!"}) That is really it! The object returned is a ruby hash that is decoded from Twitter's json response. JSON parsing is used because of the .json extension in the path of the request. You can also explicitly set a format (see the examples). That works and all but what if you don't want to embed your username and password in the class? Below is an example to fix that: class Twitter include HTTParty base_uri 'twitter.com' def initialize(user, pass) self.class.basic_auth user, pass end def post(text) self.class.post('/statuses/update.json', :query => {:status => text}) end end Twitter.new('username', 'password').post("It's an HTTParty and everyone is invited!") == REQUIREMENTS: * Active Support >= 2.1 == INSTALL: * sudo gem install httparty