Merge pull request #3580 from MathieuBordere/mathieu/3567-ReplaceMasker
websockets: replace masker with more optimized one
This commit is contained in:
commit
386772f8fc
|
@ -1,3 +1,6 @@
|
||||||
|
import sys
|
||||||
|
|
||||||
|
|
||||||
class Masker:
|
class Masker:
|
||||||
"""
|
"""
|
||||||
Data sent from the server must be masked to prevent malicious clients
|
Data sent from the server must be masked to prevent malicious clients
|
||||||
|
@ -12,12 +15,13 @@ class Masker:
|
||||||
self.offset = 0
|
self.offset = 0
|
||||||
|
|
||||||
def mask(self, offset, data):
|
def mask(self, offset, data):
|
||||||
result = bytearray(data)
|
datalen = len(data)
|
||||||
for i in range(len(data)):
|
offset_mod = offset % 4
|
||||||
result[i] ^= self.key[offset % 4]
|
data = int.from_bytes(data, sys.byteorder)
|
||||||
offset += 1
|
num_keys = (datalen + offset_mod + 3) // 4
|
||||||
result = bytes(result)
|
mask = int.from_bytes((self.key * num_keys)[offset_mod:datalen +
|
||||||
return result
|
offset_mod], sys.byteorder)
|
||||||
|
return (data ^ mask).to_bytes(datalen, sys.byteorder)
|
||||||
|
|
||||||
def __call__(self, data):
|
def __call__(self, data):
|
||||||
ret = self.mask(self.offset, data)
|
ret = self.mask(self.offset, data)
|
||||||
|
|
Loading…
Reference in New Issue