mirror of
https://github.com/rest-client/rest-client.git
synced 2022-11-09 13:49:40 -05:00
![François Beausoleil](/assets/img/avatar_default.png)
Conflicts: README.rdoc Rakefile lib/request_errors.rb lib/resource.rb lib/rest_client.rb lib/rest_client/request_errors.rb lib/rest_client/resource.rb lib/restclient/exceptions.rb lib/restclient/resource.rb rest-client.gemspec spec/base.rb spec/rest_client_spec.rb
101 lines
3.4 KiB
Ruby
101 lines
3.4 KiB
Ruby
require 'uri'
|
|
require 'zlib'
|
|
require 'stringio'
|
|
|
|
begin
|
|
require 'net/https'
|
|
rescue LoadError => e
|
|
raise e unless RUBY_PLATFORM =~ /linux/
|
|
raise LoadError, "no such file to load -- net/https. Try running apt-get install libopenssl-ruby"
|
|
end
|
|
|
|
require File.dirname(__FILE__) + '/restclient/request'
|
|
require File.dirname(__FILE__) + '/restclient/mixin/response'
|
|
require File.dirname(__FILE__) + '/restclient/response'
|
|
require File.dirname(__FILE__) + '/restclient/raw_response'
|
|
require File.dirname(__FILE__) + '/restclient/resource'
|
|
require File.dirname(__FILE__) + '/restclient/exceptions'
|
|
require File.dirname(__FILE__) + '/restclient/payload'
|
|
require File.dirname(__FILE__) + '/restclient/net_http_ext'
|
|
|
|
# This module's static methods are the entry point for using the REST client.
|
|
#
|
|
# # GET
|
|
# xml = RestClient.get 'http://example.com/resource'
|
|
# jpg = RestClient.get 'http://example.com/resource', :accept => 'image/jpg'
|
|
#
|
|
# # authentication and SSL
|
|
# RestClient.get 'https://user:password@example.com/private/resource'
|
|
#
|
|
# # POST or PUT with a hash sends parameters as a urlencoded form body
|
|
# RestClient.post 'http://example.com/resource', :param1 => 'one'
|
|
#
|
|
# # nest hash parameters
|
|
# RestClient.post 'http://example.com/resource', :nested => { :param1 => 'one' }
|
|
#
|
|
# # POST and PUT with raw payloads
|
|
# RestClient.post 'http://example.com/resource', 'the post body', :content_type => 'text/plain'
|
|
# RestClient.post 'http://example.com/resource.xml', xml_doc
|
|
# RestClient.put 'http://example.com/resource.pdf', File.read('my.pdf'), :content_type => 'application/pdf'
|
|
#
|
|
# # DELETE
|
|
# RestClient.delete 'http://example.com/resource'
|
|
#
|
|
# # retreive the response http code and headers
|
|
# res = RestClient.get 'http://example.com/some.jpg'
|
|
# res.code # => 200
|
|
# res.headers[:content_type] # => 'image/jpg'
|
|
#
|
|
# # HEAD
|
|
# RestClient.head('http://example.com').headers
|
|
#
|
|
# To use with a proxy, just set RestClient.proxy to the proper http proxy:
|
|
#
|
|
# RestClient.proxy = "http://proxy.example.com/"
|
|
#
|
|
# Or inherit the proxy from the environment:
|
|
#
|
|
# RestClient.proxy = ENV['http_proxy']
|
|
#
|
|
# For live tests of RestClient, try using http://rest-test.heroku.com, which echoes back information about the rest call:
|
|
#
|
|
# >> RestClient.put 'http://rest-test.heroku.com/resource', :foo => 'baz'
|
|
# => "PUT http://rest-test.heroku.com/resource with a 7 byte payload, content type application/x-www-form-urlencoded {\"foo\"=>\"baz\"}"
|
|
#
|
|
module RestClient
|
|
def self.get(url, headers={})
|
|
Request.execute(:method => :get, :url => url, :headers => headers)
|
|
end
|
|
|
|
def self.post(url, payload, headers={})
|
|
Request.execute(:method => :post, :url => url, :payload => payload, :headers => headers)
|
|
end
|
|
|
|
def self.put(url, payload, headers={})
|
|
Request.execute(:method => :put, :url => url, :payload => payload, :headers => headers)
|
|
end
|
|
|
|
def self.delete(url, headers={})
|
|
Request.execute(:method => :delete, :url => url, :headers => headers)
|
|
end
|
|
|
|
def self.head(url, headers={})
|
|
Request.execute(:method => :head, :url => url, :headers => headers)
|
|
end
|
|
|
|
class << self
|
|
attr_accessor :proxy
|
|
end
|
|
|
|
# Print log of RestClient calls. Value can be stdout, stderr, or a filename.
|
|
# You can also configure logging by the environment variable RESTCLIENT_LOG.
|
|
def self.log=(log)
|
|
@@log = log
|
|
end
|
|
|
|
def self.log # :nodoc:
|
|
return ENV['RESTCLIENT_LOG'] if ENV['RESTCLIENT_LOG']
|
|
return @@log if defined? @@log
|
|
nil
|
|
end
|
|
end
|