Sha256: fcbf1d8453cdabedecdbe7d8d336787a6525be74a717f63622018539fdd7895c
Contents?: true
Size: 1.63 KB
Versions: 2
Compression:
Stored size: 1.63 KB
Contents
require 'rubygems' require 'socket' require 'libwebsocket' require 'openssl' module PusherClient class WebSocket def initialize(url, params = {}) @hs ||= LibWebSocket::OpeningHandshake::Client.new(:url => url, :version => params[:version]) @frame ||= LibWebSocket::Frame.new @socket = TCPSocket.new(@hs.url.host, @hs.url.port || 80) if params[:ssl] == true ctx = OpenSSL::SSL::SSLContext.new ctx.verify_mode = OpenSSL::SSL::VERIFY_PEER|OpenSSL::SSL::VERIFY_FAIL_IF_NO_PEER_CERT # http://curl.haxx.se/ca/cacert.pem ctx.ca_file = path_to_cert() ssl_sock = OpenSSL::SSL::SSLSocket.new(@socket, ctx) ssl_sock.sync_close = true ssl_sock.connect @socket = ssl_sock end @socket.write(@hs.to_s) @socket.flush loop do data = @socket.getc next if data.nil? result = @hs.parse(data.chr) raise @hs.error unless result if @hs.done? @handshaked = true break end end end def path_to_cert File.join(File.dirname(File.expand_path(__FILE__)), '../../certs/cacert.pem') end def send(data) raise "no handshake!" unless @handshaked data = @frame.new(data).to_s @socket.write data @socket.flush end def receive raise "no handshake!" unless @handshaked data = @socket.gets("\xff") @frame.append(data) messages = [] while message = @frame.next messages << message end messages end def socket @socket end def close @socket.close end end end
Version data entries
2 entries across 2 versions & 2 rubygems
Version | Path |
---|---|
pusher-client-0.2.2 | lib/pusher-client/websocket.rb |
pusher-client-merman-0.2.1 | lib/pusher-client/websocket.rb |