public
Description: Asynchronous HTTP Client (EventMachine + Ruby)
Homepage:
Clone URL: git://github.com/igrigorik/em-http-request.git
name age message
file .gitignore Sun Feb 01 10:47:43 -0800 2009 Ignore build products and extconf artifacts. [careo]
file LICENSE Fri Aug 22 10:56:57 -0700 2008 initial import [igrigorik]
file README.rdoc Sun Oct 25 12:58:34 -0700 2009 adding getting started / installing the gem sec... [igrigorik]
file Rakefile Mon Nov 16 13:27:23 -0800 2009 added mock tests [joshbuddy]
file VERSION Thu Oct 29 15:55:06 -0700 2009 Version bump to 0.2.2 [igrigorik]
directory examples/ Sun Oct 25 12:33:07 -0700 2009 use local em-http in fetch [igrigorik]
directory ext/ Sun Oct 25 12:15:27 -0700 2009 rebuild http11_parser.c from http11_parser.rl ... [astro]
directory lib/ Thu Nov 19 06:31:15 -0800 2009 Merge commit 'joshbuddy/master' Conflicts: li... [igrigorik]
directory test/ Thu Nov 19 06:31:15 -0800 2009 Merge commit 'joshbuddy/master' Conflicts: li... [igrigorik]
README.rdoc

EM-HTTP-Client

EventMachine based HTTP Request interface. Supports streaming response processing, uses Ragel HTTP parser.

  • Simple interface for single & parallel requests via deferred callbacks
  • Automatic gzip & deflate decoding
  • Basic-Auth support
  • Custom timeouts

Screencast / Demo of using EM-HTTP-Request:

Getting started

  # install & configure gemcutter repos
  gem update --system
  gem install gemcutter
  gem tumble

  gem install em-http-request

  irb:0> require 'em-http'

Simple client example

  EventMachine.run {
    http = EventMachine::HttpRequest.new('http://127.0.0.1/').get :query => {'keyname' => 'value'}, :timeout => 10

    http.callback {
      p http.response_header.status
      p http.response_header
      p http.response

      EventMachine.stop
    }
  }

Multi request example

  EventMachine.run {
    multi = EventMachine::MultiRequest.new

    # add multiple requests to the multi-handler
    multi.add(EventMachine::HttpRequest.new('http://www.google.com/').get)
    multi.add(EventMachine::HttpRequest.new('http://www.yahoo.com/').get)

    multi.callback  {
      p multi.responses[:succeeded]
      p multi.responses[:failed]

      EventMachine.stop
    }
  }

Basic-Auth example

  EventMachine.run {
    http = EventMachine::HttpRequest.new('http://www.website.com/').get :head => {'authorization' => ['user', 'pass']}

    http.errback { failed }
    http.callback {
      p http.response_header

      EventMachine.stop
    }
  }

POST example

  EventMachine.run {
    http1 = EventMachine::HttpRequest.new('http://www.website.com/').post :body => {"key1" => 1, "key2" => [2,3]}
    http2 = EventMachine::HttpRequest.new('http://www.website.com/').post :body => "some data"

    # ...
  }

Streaming body processing

  EventMachine.run {
    http = EventMachine::HttpRequest.new('http://www.website.com/').get
    http.stream { |chunk| print chunk }

    # ...
  }