-
Notifications
You must be signed in to change notification settings - Fork 464
Extensions
One of our goals in writing Koala is to make a library anyone can use. In particular, we didn’t want to tie the library to a particular mechanism for making network requests to Facebook. Typhoeus may be our library of choice, but Koala doesn’t really care if you’d rather use Curb or HTTParty or just plain old Net::HTTP.
Using Koala with another HTTP library is simple — just write a really quick module defining one class-level method called make_request:
module MyHTTPService # this provides basic shared functionality include Koala::HTTPService
def self.make_request(path, args, verb, options = {}) # make the request # return the body of the result as a Koala::Response object Koala::Response.new(http_status, response_body, header_hash) end end
When Koala is loaded, it checks to see if Typhoeus is installed; if not, it silently falls back to Net::HTTP for requests. To use your module instead, just call
Koala.http_service = YourModule
The http_service= method will include your module, overwriting the existing make_request method. (You can check out lib/http_services.rb to see how the built-in HTTP modules are designed.)
For consistency, your module should ideally support the following:
- Uploading photos: as of 1.0 beta, Koala supports photo and file uploads. If you don’t want to implement photo-sharing, you can call back to the basic Net::HTTP implementation (for sample code, see the Typhoeus module in this revision)
- SSL: for speed, Koala’s built-in moduels make public requests (e.g. ones without access tokens) using http, not https. If your module does the same, it should recognize the @always_use_ssl accessor (provided by Koala::HTTPService) or options[:use_ssl] to set SSL for all requests or an individual request, respectively.
Voila! You’re done.
All the methods in the API classes are ultimately wrappers for a method named api, which makes a request and parses the response. In everyday life you probably won’t need to access the api method directly, but it’s important to know in case you want to extend Koala to use a different HTTP library.
def api(path, args = {}, verb = "get", options = {}, &error_checking_block) # ...other code... # make the request via the provided service result = Koala.make_request(path, args, verb, options)
# ...other code...
# now return the desired information if options[:http_component] result.send(options[:http_component]) else result.body end end
There’s a lot of interesting stuff going on in that method, but what you really need to remember when writing an HTTP service module is that it offer a make_request method with the above signature and return a Koala::Response instance.
You can also use the same mechanism to implement request logging. Just stick some logging inside the make_request method — you can even call super to actually send the request. You can track what calls are made, how long they take, whatever you find useful.
Whether you’re using timeout.rb or SystemTimer, you can easily wrap the make_request method to achieve your desired timeout behavior.
Since Koala just implements a basic wrapper for the Graph API, there’s no reason Koala couldn’t be used inside any other systems, including other Facebook libraries that provide higher-level data encapsulation and convenience methods. Just sayin’.