summaryrefslogtreecommitdiffstats
path: root/module/plugins/container
diff options
context:
space:
mode:
Diffstat (limited to 'module/plugins/container')
-rw-r--r--module/plugins/container/DLC.py85
1 files changed, 43 insertions, 42 deletions
diff --git a/module/plugins/container/DLC.py b/module/plugins/container/DLC.py
index 5af41ac94..446e96221 100644
--- a/module/plugins/container/DLC.py
+++ b/module/plugins/container/DLC.py
@@ -1,69 +1,70 @@
# -*- coding: utf-8 -*-
-import base64
+from __future__ import with_statement
+
import re
+import xml
+from base64 import standard_b64decode
from Crypto.Cipher import AES
-from xml.dom.minidom import parseString
from module.plugins.Container import Container
class DLC(Container):
__name__ = "DLC"
- __pattern__ = r'.*\.dlc$'
- __version__ = "0.2"
- __description__ = """DLC Container Decode Plugin"""
- __author_name__ = ("RaNaN", "spoob", "mkaay", "Schnusch")
- __author_mail__ = ("RaNaN@pyload.org", "spoob@pyload.org", "mkaay@mkaay.de", "Schnusch@users.noreply.github.com")
+ __version__ = "0.20"
+ __pattern__ = r'.+\.dlc$'
+
+ __description__ = """DLC container decrypter plugin"""
+ __license__ = "GPLv3"
+ __authors__ = [("RaNaN", "RaNaN@pyload.org"),
+ ("spoob", "spoob@pyload.org"),
+ ("mkaay", "mkaay@mkaay.de"),
+ ("Schnusch", "Schnusch@users.noreply.github.com")]
+
+
+ def setup(self):
+ self.key = "cb99b5cbc24db398"
+ self.iv = "9bc24cb995cb8db3"
+ self.api_url = "http://service.jdownloader.org/dlcrypt/service.php?srcType=dlc&destType=pylo&data="
- key = "cb99b5cbc24db398"
- iv = "9bc24cb995cb8db3"
- dlc_api_url = "http://service.jdownloader.org/dlcrypt/service.php?srcType=dlc&destType=pylo&data="
def decrypt(self, pyfile):
- infile = pyfile.url.replace("\n", "")
+ with open(pyfile.url.replace("\n", "")) as dlc:
+ data = dlc.read().strip()
- dlc = open(infile, "r")
- data = dlc.read().strip()
- dlc.close()
if not data.endswith("=="):
- if data.endswith("="):
- data += "="
- else:
- data += "=="
- dlckey = data[-88:]
+ data += "=" if data.endswith("=") else "=="
+
+ dlckey = data[-88:]
dlcdata = data[:-88]
- dlcdata = base64.standard_b64decode(dlcdata)
- rc = self.req.load(self.dlc_api_url + dlckey)
+ dlcdata = standard_b64decode(dlcdata)
+
+ rc = self.req.load(self.api_url + dlckey)
rc = re.search(r'<rc>(.+)</rc>', rc).group(1)
- rc = base64.standard_b64decode(rc)
- obj = AES.new(self.key, AES.MODE_CBC, self.iv)
+ rc = standard_b64decode(rc)
+
+ obj = AES.new(self.key, AES.MODE_CBC, self.iv)
dlckey = obj.decrypt(rc)
- obj = AES.new(dlckey, AES.MODE_CBC, dlckey)
- self.data = base64.standard_b64decode(obj.decrypt(dlcdata))
- for entry in self.getPackages():
- self.packages.append((entry[0] if entry[0] else pyfile.name, entry[1], entry[0] if entry[0] else pyfile.name))
+ obj = AES.new(dlckey, AES.MODE_CBC, dlckey)
+
+ self.data = standard_b64decode(obj.decrypt(dlcdata))
+ self.packages = [(entry[0] if entry[0] else pyfile.name, entry[1], entry[0] if entry[0] else pyfile.name) \
+ for entry in self.getPackages()]
- def createNewPackage(self):
- return True
def getPackages(self):
- xml = parseString(self.data)
- root = xml.documentElement
- contentNode = root.getElementsByTagName("content")[0]
- return self.parsePackages(contentNode)
+ root = xml.dom.minidom.parseString(self.data).documentElement
+ content = root.getElementsByTagName("content")[0]
+ return self.parsePackages(content)
+
def parsePackages(self, startNode):
- c = []
- for node in startNode.getElementsByTagName("package"):
- c.append((base64.standard_b64decode(node.getAttribute("name")).decode("utf8", "replace"), self.parseLinks(node)))
+ return [(standard_b64decode(node.getAttribute("name")).decode("utf8", "replace"), self.parseLinks(node)) \
+ for node in startNode.getElementsByTagName("package")]
- return c
def parseLinks(self, startNode):
- c = []
- for node in startNode.getElementsByTagName("file"):
- c.append(base64.standard_b64decode(node.getElementsByTagName("url")[0].firstChild.data))
-
- return c
+ return [standard_b64decode(node.getElementsByTagName("url")[0].firstChild.data) \
+ for node in startNode.getElementsByTagName("file")]