summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--module/HookManager.py71
-rw-r--r--module/file_list.py2
-rw-r--r--module/thread_list.py4
-rwxr-xr-xpyLoadCore.py8
-rw-r--r--scripts/Readme.txt25
5 files changed, 94 insertions, 16 deletions
diff --git a/module/HookManager.py b/module/HookManager.py
index 3a1a3d533..5dbf41936 100644
--- a/module/HookManager.py
+++ b/module/HookManager.py
@@ -17,28 +17,46 @@
@author: mkaay
@interface-version: 0.1
"""
+from glob import glob
import logging
+from os import listdir
+from os.path import basename
+from os.path import join
+import subprocess
+from threading import Lock
from module.XMLConfigParser import XMLConfigParser
-from os.path import basename, join
-from glob import glob
-
-from threading import Lock
-
class HookManager():
def __init__(self, core):
self.core = core
- self.configParser = XMLConfigParser(join("module","config","plugin.xml"))
+ self.configParser = XMLConfigParser(join("module", "config", "plugin.xml"))
self.configParser.loadData()
self.config = self.configParser.getConfig()
self.logger = logging.getLogger("log")
self.plugins = []
+ self.scripts = {}
self.lock = Lock()
self.createIndex()
def createIndex(self):
self.lock.acquire()
+
+ f = lambda x: False if x.startswith("#") or x.endswith("~") else True
+ self.scripts = {}
+
+ folder = join(self.core.path, "scripts")
+
+ self.scripts['download_preparing'] = filter(f, listdir(join(folder, 'download_preparing')))
+ self.scripts['download_finished'] = filter(f, listdir(join(folder, 'download_finished')))
+ self.scripts['package_finished'] = filter(f, listdir(join(folder, 'package_finished')))
+ self.scripts['before_reconnect'] = filter(f, listdir(join(folder, 'before_reconnect')))
+ self.scripts['after_reconnect'] = filter(f, listdir(join(folder, 'after_reconnect')))
+
+ self.core.logger.info("Installed Scripts: %s" % str(self.scripts))
+
+ self.folder = folder
+
pluginFiles = glob(join(self.core.plugin_folder, "hooks", "*.py"))
plugins = []
for pluginFile in pluginFiles:
@@ -50,8 +68,8 @@ class HookManager():
self.logger.info("Deactivated %s" % pluginName)
continue
else:
- self.configParser.set(pluginName, {"option": "activated", "type": "bool", "name": "Activated"}, True)
- module = __import__("module.plugins.hooks."+pluginName, globals(), locals(), [pluginName], -1)
+ self.configParser.set(pluginName, {"option": "activated", "type": "bool", "name": "Activated"}, True)
+ module = __import__("module.plugins.hooks." + pluginName, globals(), locals(), [pluginName], -1)
pluginClass = getattr(module, pluginName)
plugin = pluginClass(self.core)
plugin.readConfig()
@@ -63,24 +81,59 @@ class HookManager():
def downloadStarts(self, pyfile):
self.lock.acquire()
+
+ for script in self.scripts['download_preparing']:
+ try:
+ out = subprocess.Popen([join(self.folder, 'download_preparing', script), pyfile.plugin.props['name'], pyfile.url], stdout=subprocess.PIPE)
+ out.wait()
+ except:
+ pass
+
for plugin in self.plugins:
plugin.downloadStarts(pyfile)
self.lock.release()
def downloadFinished(self, pyfile):
self.lock.acquire()
+
+ for script in self.scripts['download_finished']:
+ try:
+ out = subprocess.Popen([join(self.folder, 'download_finished', script), pyfile.plugin.props['name'], pyfile.url, pyfile.status.name, \
+ join(self.core.path,self.core.config['general']['download_folder'], pyfile.folder, pyfile.status.name)], stdout=subprocess.PIPE)
+ except:
+ pass
+
+
for plugin in self.plugins:
plugin.downloadFinished(pyfile)
self.lock.release()
-
+
+ def packageFinished(self, pyfile, package):
+ raise NotImplementedError
+
def beforeReconnecting(self, ip):
self.lock.acquire()
+
+ for script in self.scripts['before_reconnect']:
+ try:
+ out = subprocess.Popen([join(self.folder, 'before_reconnect', script), ip], stdout=subprocess.PIPE)
+ out.wait()
+ except:
+ pass
+
for plugin in self.plugins:
plugin.beforeReconnecting(ip)
self.lock.release()
def afterReconnecting(self, ip):
self.lock.acquire()
+
+ for script in self.scripts['after_reconnect']:
+ try:
+ out = subprocess.Popen([join(self.folder, 'download_preparing', script), ip], stdout=subprocess.PIPE)
+ except:
+ pass
+
for plugin in self.plugins:
plugin.afterReconnecting(ip)
self.lock.release()
diff --git a/module/file_list.py b/module/file_list.py
index 1c4c4776b..7c68a7427 100644
--- a/module/file_list.py
+++ b/module/file_list.py
@@ -149,7 +149,7 @@ class File_List(object):
info["active"] = pyfile.active
info["plugin"] = pyfile.plugin.props['name']
return info
-
+
def continueAborted(self):
[[self.packager.resetFileStatus(x.id) for x in p.files if x.status.type == "aborted"] for p in self.data["queue"]]
diff --git a/module/thread_list.py b/module/thread_list.py
index 9211c7c2e..1a66bf6f5 100644
--- a/module/thread_list.py
+++ b/module/thread_list.py
@@ -200,7 +200,7 @@ class Thread_List(object):
def reconnect(self):
self.parent.logger.info("Start reconnect")
ip = re.match(".*Current IP Address: (.*)</body>.*", urllib2.urlopen("http://checkip.dyndns.org/").read()).group(1)
- #self.parent.hookManager.beforeReconnecting(ip)
+ self.parent.hookManager.beforeReconnecting(ip)
reconn = subprocess.Popen(self.parent.config['reconnect']['method'])#, stdout=subprocess.PIPE)
reconn.wait()
time.sleep(1)
@@ -211,7 +211,7 @@ class Thread_List(object):
except:
ip = ""
time.sleep(1)
- #self.parent.hookManager.afterReconnecting(ip)
+ self.parent.hookManager.afterReconnecting(ip)
self.parent.logger.info("Reconnected, new IP: " + ip)
def stopAllDownloads(self):
diff --git a/pyLoadCore.py b/pyLoadCore.py
index 9a9c0d6ff..7aa38b9b1 100755
--- a/pyLoadCore.py
+++ b/pyLoadCore.py
@@ -104,7 +104,7 @@ class Core(object):
self.do_kill = False
self.do_restart = False
- translation = gettext.translation("pyLoad", "locale", languages=[self.config['general']['language']])
+ translation = gettext.translation("pyLoad", join(self.path, "locale"), languages=[self.config['general']['language']])
translation.install(unicode=True)
self.check_install("Crypto", "pycrypto to decode container files")
@@ -347,10 +347,10 @@ class Core(object):
self.last_update_check = time.time()
def install_update(self):
- if self.config['updates']['search_updates']:
+ if self.config['updates']['search_updates']:
if self.core.config['updates']['install_updates']:
- version_check = Request().load("http://get.pyload.org/get/update/%s/" % (CURRENT_VERSION, ))
- else:
+ version_check = Request().load("http://get.pyload.org/get/update/%s/" % (CURRENT_VERSION, ))
+ else:
version_check = Request().load("http://get.pyload.org/check/%s/" % (CURRENT_VERSION, ))
if version_check == "":
return False
diff --git a/scripts/Readme.txt b/scripts/Readme.txt
new file mode 100644
index 000000000..1c326801d
--- /dev/null
+++ b/scripts/Readme.txt
@@ -0,0 +1,25 @@
+ #############################
+ ### pyLoad Script Support ###
+ #############################
+
+pyLoad is able to start any kind of scripts at given events.
+Simply put your script in a suitable folder and pyLoad will execute it at the given events and pass some arguments to them.
+
+--> Note: Scripts, which starts with # will be ignored!
+For Example: #converter.sh will not be executed.
+
+--> Note: You have to restart pyload when you change script names or locations.
+
+Below you see the list of arguments, which are passed to the scripts.
+
+## Argument list ##
+
+download_preparing: pluginname url
+
+download_finished: pluginname url filename filelocation
+
+package_finshed: packagename packagelocation
+
+before_reconnect: oldip
+
+after_reconnect: newip \ No newline at end of file