[tor-commits] [flashproxy/master] Don't use "base64" WebSockets when we don't have to.
dcf at torproject.org
dcf at torproject.org
Mon Apr 9 04:08:43 UTC 2012
commit 7be603c856de465225936a5ed443ce69b69b5f16
Author: David Fifield <david at bamsoftware.com>
Date: Wed Apr 4 23:13:19 2012 -0700
Don't use "base64" WebSockets when we don't have to.
Currently it's assumed that binary frames never work, so this doesn't
effectively change anything.
---
flashproxy.js | 24 +++++++++++++++++++++++-
1 files changed, 23 insertions(+), 1 deletions(-)
diff --git a/flashproxy.js b/flashproxy.js
index 25f23fb..10ed935 100644
--- a/flashproxy.js
+++ b/flashproxy.js
@@ -255,14 +255,36 @@ function format_addr(addr)
return addr.host + ":" + addr.port;
}
+/* Does the WebSocket implementation in this browser support binary frames? (RFC
+ 6455 section 5.6.) If not, we have to use base64-encoded text frames. It is
+ assumed that the client and relay endpoints always support binary frames. */
+function have_websocket_binary_frames()
+{
+ return false;
+}
+
function make_websocket(addr)
{
var url;
+ var WebSocket;
+ var ws;
url = "ws://" + encodeURIComponent(addr.host)
+ ":" + encodeURIComponent(addr.port) + "/";
- return new (window.WebSocket || window.MozWebSocket)(url, "base64");
+ WebSocket = window.WebSocket || window.MozWebSocket;
+
+ if (have_websocket_binary_frames())
+ ws = new WebSocket(url);
+ else
+ ws = new WebSocket(url, "base64");
+ /* "User agents can use this as a hint for how to handle incoming binary
+ data: if the attribute is set to 'blob', it is safe to spool it to disk,
+ and if it is set to 'arraybuffer', it is likely more efficient to keep
+ the data in memory." */
+ ws.binaryType = "arraybuffer";
+
+ return ws;
}
function FlashProxy()
More information about the tor-commits
mailing list