Class to handle connections to remote web services. This class is used by
ActiveResource::Base to interface with REST
services.
     
    
    
    
    
    
    
    Methods
    
    
        - A
- 
            
        
- D
- 
            
        
- G
- 
            
        
- H
- 
            
        
- N
- 
            
        
- P
- 
            
        
- R
- 
            
        
- S
- 
            
        
- T
- 
            
        
- U
- 
            
        
Constants
    
        
        
            | HTTP_FORMAT_HEADER_NAMES | = | {  :get => 'Accept',       :put => 'Content-Type',       :post => 'Content-Type',       :delete => 'Accept',       :head => 'Accept'     } | 
        
        
    
    
    
    Attributes
    
        
        
            | [R] | site |  | 
        
        
            | [R] | user |  | 
        
        
            | [R] | password |  | 
        
        
            | [R] | auth_type |  | 
        
        
            | [R] | timeout |  | 
        
        
            | [R] | proxy |  | 
        
        
            | [R] | ssl_options |  | 
        
        
            | [RW] | format |  | 
        
    
    
    
            Class Public methods
            
            
                
                    
                    new(site, format = ActiveResource::Formats::JsonFormat)
                    
                
 
                
                
                  
The site parameter is required and will set the site
attribute to the URI for the remote resource
service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
33:     def initialize(site, format = ActiveResource::Formats::JsonFormat)
34:       raise ArgumentError, 'Missing site URI' unless site
35:       @user = @password = nil
36:       self.site = site
37:       self.format = format
38:     end
                     
                 
                
             
            
            
                
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
26:       def requests
27:         @@requests ||= []
28:       end
                     
                 
                
             
            
            Instance Public methods
            
            
                
                
                
                  
Sets the auth type for remote service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
63:     def auth_type=(auth_type)
64:       @auth_type = legitimize_auth_type(auth_type)
65:     end
                     
                 
                
             
            
            
                
                    
                    delete(path, headers = {})
                    
                
 
                
                
                  
Executes a DELETE request (see HTTP protocol documentation if unfamiliar).
Used to delete resources.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
85:     def delete(path, headers = {})
86:       with_auth { request(:delete, path, build_request_headers(headers, :delete, self.site.merge(path))) }
87:     end
                     
                 
                
             
            
            
                
                
                
                  
Executes a GET request. Used to get (find) resources.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
79:     def get(path, headers = {})
80:       with_auth { request(:get, path, build_request_headers(headers, :get, self.site.merge(path))) }
81:     end
                     
                 
                
             
            
            
                
                
                
                  
Executes a HEAD request. Used to obtain meta-information about resources,
such as whether they exist and their size (via response headers).
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                             
103:     def head(path, headers = {})
104:       with_auth { request(:head, path, build_request_headers(headers, :head, self.site.merge(path))) }
105:     end
                     
                 
                
             
            
            
                
                
                
                  
Sets the password for remote service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
58:     def password=(password)
59:       @password = password
60:     end
                     
                 
                
             
            
            
                
                    
                    post(path, body = '', headers = {})
                    
                
 
                
                
                  
Executes a POST request. Used to create new resources.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
97:     def post(path, body = '', headers = {})
98:       with_auth { request(:post, path, body.to_s, build_request_headers(headers, :post, self.site.merge(path))) }
99:     end
                     
                 
                
             
            
            
                
                
                
                  
Set the proxy for remote service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
48:     def proxy=(proxy)
49:       @proxy = proxy.is_a?(URI) ? proxy : URI.parser.parse(proxy)
50:     end
                     
                 
                
             
            
            
                
                    
                    put(path, body = '', headers = {})
                    
                
 
                
                
                  
Executes a PUT request (see HTTP protocol documentation if unfamiliar).
Used to update resources.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
91:     def put(path, body = '', headers = {})
92:       with_auth { request(:put, path, body.to_s, build_request_headers(headers, :put, self.site.merge(path))) }
93:     end
                     
                 
                
             
            
            
                
                
                
                  
Set URI for remote service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
41:     def site=(site)
42:       @site = site.is_a?(URI) ? site : URI.parser.parse(site)
43:       @user = URI.parser.unescape(@site.user) if @site.user
44:       @password = URI.parser.unescape(@site.password) if @site.password
45:     end
                     
                 
                
             
            
            
                
                
                
                  
Hash of options applied to Net::HTTP instance
when site protocol is ‘https’.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
73:     def ssl_options=(opts={})
74:       @ssl_options = opts
75:     end
                     
                 
                
             
            
            
                
                
                
                  
Sets the number of seconds after which HTTP requests to the remote service
should time out.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
68:     def timeout=(timeout)
69:       @timeout = timeout
70:     end
                     
                 
                
             
            
            
                
                
                
                  
Sets the user for remote service.
                 
                
                
                
                
                
                    
                        Source: show
                        
                        | on GitHub
                        
                    
                    
                            
53:     def user=(user)
54:       @user = user
55:     end