summaryrefslogtreecommitdiffstats
path: root/module
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-06-14 18:37:18 +0200
committerGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-06-14 18:37:18 +0200
commit83db7b72d85b74f0248717444a622156fb4d43b9 (patch)
tree9415b67b16ca59674f205743316a985336754119 /module
parentRevert https://github.com/pyload/pyload/commit/043e3dfd83bb217ea15280fef6523f... (diff)
downloadpyload-83db7b72d85b74f0248717444a622156fb4d43b9.tar.xz
Update Crypter
Diffstat (limited to 'module')
-rw-r--r--module/plugins/internal/Crypter.py127
1 files changed, 81 insertions, 46 deletions
diff --git a/module/plugins/internal/Crypter.py b/module/plugins/internal/Crypter.py
index b87ed1882..182354287 100644
--- a/module/plugins/internal/Crypter.py
+++ b/module/plugins/internal/Crypter.py
@@ -1,35 +1,36 @@
# -*- coding: utf-8 -*-
-"""
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 3 of the License,
- or (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
- See the GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, see <http://www.gnu.org/licenses/>.
-
- @author: mkaay
-"""
-
-from module.plugins.internal.Plugin import Plugin
-
-class Crypter(Plugin):
- __name__ = "Crypter"
- __version__ = "0.02"
- __pattern__ = None
- __type__ = "container"
- __description__ = """Base crypter plugin"""
- __author_name__ = ("mkaay")
- __author_mail__ = ("mkaay@mkaay.de")
+import urlparse
+
+from module.plugins.internal.Hoster import Hoster
+from module.utils import decode, save_path
+
+
+class Crypter(Hoster):
+ """
+ Base plugin for crypter.
+ Overwrite `decrypt` in your subclassed plugin.
+ """
+
+ __name__ = "Crypter"
+ __type__ = "crypter"
+ __version__ = "0.03"
+
+ __pattern__ = r'^unmatchable$'
+ __config__ = [("use_subfolder", "bool", "Save package to subfolder", True), #: Overrides core.config.get("general", "folder_per_package")
+ ("subfolder_per_package", "bool", "Create a subfolder for each package", True)]
+
+ __description__ = """Base decrypter plugin"""
+ __license__ = "GPLv3"
+ __authors__ = [("Walter Purcaro", "vuolter@gmail.com")]
+
+
+ html = None #: last html loaded #@TODO: Move to Hoster
+
def __init__(self, pyfile):
- Plugin.__init__(self, pyfile)
+ #: Provide information in dict here
+ self.info = {} #@TODO: Move to Plugin
#: Put all packages here. It's a list of tuples like: ( name, [list of links], folder )
self.packages = []
@@ -37,36 +38,70 @@ class Crypter(Plugin):
#: List of urls, pyLoad will generate packagenames
self.urls = []
- self.multiDL = True
- self.limitDL = 0
+ Plugin.__init__(self, pyfile)
+
+ def process(self, pyfile):
+ """Main method"""
- def preprocessing(self, thread):
- """prepare"""
- self.setup()
- self.thread = thread
+ self.decrypt(pyfile)
- self.decrypt(self.pyfile)
+ if self.urls:
+ self._generate_packages()
+
+ elif not self.packages:
+ self.error(_("No link grabbed"), "decrypt")
- self.createPackages()
+ self._create_packages()
def decrypt(self, pyfile):
raise NotImplementedError
- def createPackages(self):
- """ create new packages from self.packages """
- for pack in self.packages:
- self.log.debug("Parsed package %(name)s with %(len)d links" % { "name" : pack[0], "len" : len(pack[1]) } )
+ def _generate_packages(self):
+ """Generate new packages from self.urls"""
- links = [x.decode("utf-8") for x in pack[1]]
+ packages = [(name, links, None) for name, links in self.core.api.generatePackages(self.urls).iteritems()]
+ self.packages.extend(packages)
- pid = self.core.api.addPackage(pack[0], links, self.pyfile.package().queue)
- if self.pyfile.package().password:
- self.core.api.setPackageData(pid, {"password": self.pyfile.package().password})
+ def _create_packages(self):
+ """Create new packages from self.packages"""
- if self.urls:
- self.core.api.generateAndAddPackages(self.urls)
+ package_folder = self.pyfile.package().folder
+ package_password = self.pyfile.package().password
+ package_queue = self.pyfile.package().queue
+
+ folder_per_package = self.core.config.get('general', 'folder_per_package')
+ use_subfolder = self.getConfig('use_subfolder', folder_per_package)
+ subfolder_per_package = self.getConfig('subfolder_per_package', True)
+
+ for name, links, folder in self.packages:
+ self.logDebug("Parsed package: %s" % name,
+ "%d links" % len(links),
+ "Saved to folder: %s" % folder if folder else "Saved to download folder")
+
+ links = map(decode, links)
+
+ pid = self.core.api.addPackage(name, links, package_queue)
+
+ if package_password:
+ self.core.api.setPackageData(pid, {"password": package_password})
+
+ setFolder = lambda x: self.core.api.setPackageData(pid, {"folder": x or ""}) #@NOTE: Workaround to do not break API addPackage method
+
+ if use_subfolder:
+ if not subfolder_per_package:
+ setFolder(package_folder)
+ self.logDebug("Set package %(name)s folder to: %(folder)s" % {"name": name, "folder": folder})
+
+ elif not folder_per_package or name != folder:
+ if not folder:
+ folder = urlparse.urlparse(name).path.split("/")[-1]
+
+ setFolder(save_path(folder))
+ self.logDebug("Set package %(name)s folder to: %(folder)s" % {"name": name, "folder": folder})
+ elif folder_per_package:
+ setFolder(None)