[tor-commits] [flashproxy/master] Rewrite apply_mask to use bytes.

dcf at torproject.org dcf at torproject.org
Mon Apr 9 04:08:43 UTC 2012


commit 4c9298cfed95f32561a61874d329e8328410bf62
Author: David Fifield <david at bamsoftware.com>
Date:   Sat Apr 7 10:31:56 2012 -0700

    Rewrite apply_mask to use bytes.
    
    Unlike the struct module, the array module doesn't guarantee the size of
    types. apply_mask failed because it assumed that a long "l" was four
    bytes, when it could be 8 (or really, anything greater than 4).
---
 connector.py |   27 ++++++++++++++-------------
 1 files changed, 14 insertions(+), 13 deletions(-)

diff --git a/connector.py b/connector.py
index 8653907..d10a6ab 100755
--- a/connector.py
+++ b/connector.py
@@ -126,22 +126,23 @@ def format_addr(addr):
 
 
 def apply_mask(payload, mask_key):
-    result = array.array("l")
-    result.fromstring(payload[:len(payload) // 4 * 4])
-    m, = struct.unpack("=l", mask_key)
+    result = array.array("B", payload)
+    m = array.array("B", mask_key)
     i = 0
+    while i < len(result) - 7:
+        result[i] ^= m[0]
+        result[i+1] ^= m[1]
+        result[i+2] ^= m[2]
+        result[i+3] ^= m[3]
+        result[i+4] ^= m[0]
+        result[i+5] ^= m[1]
+        result[i+6] ^= m[2]
+        result[i+7] ^= m[3]
+        i += 8
     while i < len(result):
-        result[i] ^= m
+        result[i] ^= m[i%4]
         i += 1
-    result = result.tostring()
-    i *= 4
-    if i < len(payload):
-        remainder = []
-        while i < len(payload):
-            remainder.append(chr(ord(payload[i]) ^ ord(mask_key[i%4])))
-            i += 1
-        result = result + "".join(remainder)
-    return result
+    return result.tostring()
 
 class WebSocketFrame(object):
     def __init__(self):





More information about the tor-commits mailing list