# File debug-1.4.0/lib/debug/server_cdp.rb, line 144 def extract_data first_group = @sock.getbyte fin = first_group & 0b10000000 != 128 raise 'Unsupported' if fin opcode = first_group & 0b00001111 raise "Unsupported: #{opcode}" unless opcode == 1 second_group = @sock.getbyte mask = second_group & 0b10000000 == 128 raise 'The server must not mask any frames' if mask payload_len = second_group & 0b01111111 # TODO: Support other payload_lengths if payload_len == 126 payload_len = @sock.read(2).unpack('n*')[0] end data = JSON.parse @sock.read payload_len $stderr.puts '[>]' + data.inspect if SHOW_PROTOCOL data end
# File debug-1.4.0/lib/debug/server_cdp.rb, line 98 def handshake port, path key = SecureRandom.hex(11) @sock.print "GET #{path} HTTP/1.1\r\nHost: 127.0.0.1:#{port}\r\nConnection: Upgrade\r\nUpgrade: websocket\r\nSec-WebSocket-Version: 13\r\nSec-WebSocket-Key: #{key}==\r\n\r\n" res = @sock.readpartial 4092 $stderr.puts '[>]' + res if SHOW_PROTOCOL if res.match /^Sec-WebSocket-Accept: (.*)\r\n/ correct_key = Base64.strict_encode64 Digest::SHA1.digest "#{key}==258EAFA5-E914-47DA-95CA-C5AB0DC85B11" raise "The Sec-WebSocket-Accept value: #{$1} is not valid" unless $1 == correct_key else raise "Unknown response: #{res}" end end
# File debug-1.4.0/lib/debug/server_cdp.rb, line 112 def send **msg msg = JSON.generate(msg) frame = [] fin = 0b10000000 opcode = 0b00000001 frame << fin + opcode mask = 0b10000000 # A client must mask all frames in a WebSocket Protocol. bytesize = msg.bytesize if bytesize < 126 payload_len = bytesize elsif bytesize < 2 ** 16 payload_len = 0b01111110 ex_payload_len = [bytesize].pack('n*').bytes else payload_len = 0b01111111 ex_payload_len = [bytesize].pack('Q>').bytes end frame << mask + payload_len frame.push *ex_payload_len if ex_payload_len frame.push *masking_key = 4.times.map{rand(1..255)} masked = [] msg.bytes.each_with_index do |b, i| masked << (b ^ masking_key[i % 4]) end frame.push *masked @sock.print frame.pack 'c*' end