diff options
author | RaNaN <Mast3rRaNaN@hotmail.de> | 2009-05-29 13:37:46 +0200 |
---|---|---|
committer | RaNaN <Mast3rRaNaN@hotmail.de> | 2009-05-29 13:37:46 +0200 |
commit | 37104032902281caefa144ed039b88c4f3b6e81e (patch) | |
tree | 560e1ab570dde87edebbbb6c8e28fba30f80e738 /module/remote/RequestHandler.py | |
parent | added download plugin for fileuploadx.de, fixed some bugs (diff) | |
download | pyload-37104032902281caefa144ed039b88c4f3b6e81e.tar.xz |
socket encryption
Diffstat (limited to 'module/remote/RequestHandler.py')
-rw-r--r-- | module/remote/RequestHandler.py | 38 |
1 files changed, 30 insertions, 8 deletions
diff --git a/module/remote/RequestHandler.py b/module/remote/RequestHandler.py index 9964c90c0..c72f6eaaa 100644 --- a/module/remote/RequestHandler.py +++ b/module/remote/RequestHandler.py @@ -8,22 +8,44 @@ this module handels the incoming requests """ import base64 -from cPickle import Pickler -from cStringIO import StringIO +import cPickle +import random +import string from Crypto.Cipher import AES +from Crypto.Hash import SHA class RequestHandler(): def __init__(self, core): self.core = core - self.p = Pickler(string) - self.obj = AES.new('pw', AES.MODE_ECB) + key = SHA.new(core.config['remotepassword']) + self.aes = AES.new(key.hexdigest()[:32], AES.MODE_ECB) def proceed(self, data): - return "the answer." + return self.encrypt({'befehl' : None , 'args':[1,2,3], 'test': 'lol'}) + + def decrypt(self, dec_str): + dec_str = base64.standard_b64decode(dec_str) + dec_str = self.aes.decrypt(dec_str) + + dec_str = dec_str[:-(int(dec_str[-1],16)+1)] + obj = cPickle.loads(dec_str) + return obj + + def encrypt(self, obj): + enc_str = cPickle.dumps(obj, 1) + padding = len(enc_str) % 16 + padding = 16 - padding + + p_str = "" + for i in range(padding - 1): + p_str += random.choice(string.letters+string.digits) + p_str += hex(len(p_str)).replace("0x","") + enc_str += p_str + + enc_str = self.aes.encrypt(enc_str) + enc_str = base64.standard_b64encode(enc_str) + return enc_str - def decrypt(self, string): - string = string - buf = StringIO(string) |