Skip to content

Latest commit

 

History

History
95 lines (79 loc) · 2.75 KB

README.md

File metadata and controls

95 lines (79 loc) · 2.75 KB

ChromiumRemoteDebugging

This gem is under development and doesn't work yet.

A library for ruby to manipulate Chromium Remote Debugging API

Objective

client = ChromiumRemoteDebugging::Client.new('localhost', 9222)
EM.run do
  Client.pages.each do |page|
    page.em_run do |socket|
      socket.onopen do |handshake|
        puts "onopen"
      end
      socket.onclose do
        puts "onclose"
      end
      socket.onnotification "Network.dataReceived" do
        puts "received Network.dataReceived notification"
      end
      socket.send_command "Network.getResponseBody", {"requestId" => 1} do |response|
        puts response
      end
    end
  end
end

Usage

# on Mac OSX
$ "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome" --user-data-dir=/tmp/google_chrome --remote-debugging-port=9222
[1] pry(main)> require 'chromium_remote_debugging'
=> true
[2] pry(main)> client = ChromiumRemoteDebugging::Client.new('localhost', 9222)

=> #<ChromiumRemoteDebugging::Client:0x007febab5b3b48
 @host="localhost",
 @port=9222>
[3] pry(main)> client.pages
=> [#<ChromiumRemoteDebugging::Page:0x007febab10c590
  @devtoolsFrontendUrl=
   "/devtools/devtools.html?ws=localhost:9222/devtools/page/4_1",
  @faviconUrl="http://localhost:9222/favicon.ico",
  @thumbnailUrl="/thumb/http://localhost:9222/json",
  @title="localhost:9222/json",
  @url="http://localhost:9222/json",
  @webSocketDebuggerUrl="ws://localhost:9222/devtools/page/4_1">,
 #<ChromiumRemoteDebugging::Page:0x007febab10c3d8
  @devtoolsFrontendUrl=
   "/devtools/devtools.html?ws=localhost:9222/devtools/page/15_1",
  @faviconUrl="http://www.bing.com/s/wlflag.ico",
  @thumbnailUrl="/thumb/http://www.bing.com/",
  @title="Bing",
  @url="http://www.bing.com/",
  @webSocketDebuggerUrl="ws://localhost:9222/devtools/page/15_1">,
 #<ChromiumRemoteDebugging::Page:0x007febab10c270
  @devtoolsFrontendUrl=
   "/devtools/devtools.html?ws=localhost:9222/devtools/page/13_1",
  @faviconUrl="http://www.google.co.jp/favicon.ico",
  @thumbnailUrl="/thumb/http://www.google.co.jp/",
  @title="Google",
  @url="http://www.google.co.jp/",
  @webSocketDebuggerUrl="ws://localhost:9222/devtools/page/13_1">]

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create new Pull Request