summaryrefslogtreecommitdiffstats
path: root/module/plugins
diff options
context:
space:
mode:
authorGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-12-15 05:35:10 +0100
committerGravatar Walter Purcaro <vuolter@users.noreply.github.com> 2015-12-27 22:27:49 +0100
commitb60298e1799921a1073d050c440962c39f4654b5 (patch)
treeb686f4c95c7298e657404502e4901fef3f1bdd9c /module/plugins
parent[Account] Fix reset method (diff)
downloadpyload-b60298e1799921a1073d050c440962c39f4654b5.tar.xz
[ExternalScripts] Update and fix (2)
Diffstat (limited to 'module/plugins')
-rw-r--r--module/plugins/hooks/ExternalScripts.py88
1 files changed, 56 insertions, 32 deletions
diff --git a/module/plugins/hooks/ExternalScripts.py b/module/plugins/hooks/ExternalScripts.py
index eb7958213..e77514bb5 100644
--- a/module/plugins/hooks/ExternalScripts.py
+++ b/module/plugins/hooks/ExternalScripts.py
@@ -10,7 +10,7 @@ from module.plugins.internal.misc import Expose, encode, fsjoin
class ExternalScripts(Addon):
__name__ = "ExternalScripts"
__type__ = "hook"
- __version__ = "0.56"
+ __version__ = "0.60"
__status__ = "testing"
__config__ = [("activated", "bool", "Activated" , True ),
@@ -35,6 +35,11 @@ class ExternalScripts(Addon):
'all_archives_processed': "all_archives_processed" ,
'pyload_updated' : "pyload_updated" }
+ self.start_periodical(60)
+ self.pyload_start()
+
+
+ def make_folders(self):
folders = ["pyload_start", "pyload_restart", "pyload_stop",
"before_reconnect", "after_reconnect",
"download_preparing", "download_failed", "download_finished",
@@ -44,48 +49,53 @@ class ExternalScripts(Addon):
"all_archives_extracted", "all_archives_processed"]
for folder in folders:
- path = os.path.join("scripts", folder)
- self.init_folder(folder, path)
-
- for folder, scripts in self.scripts.items():
- if scripts:
- self.log_info(_("Installed scripts in folder `%s`: %s")
- % (folder, ", ".join(scripts)))
-
- self.pyload_start()
+ dir = os.path.join("scripts", folder)
+ if os.path.isdir(dir):
+ continue
- def init_folder(self, name, path):
- self.scripts[name] = []
-
- if not os.path.isdir(path):
try:
- os.makedirs(path)
+ os.makedirs(dir)
except OSError, e:
self.log_debug(e, trace=True)
- return
- for filename in os.listdir(path):
- file = fsjoin(path, filename)
- if not os.path.isfile(file):
- continue
- if file[0] in ("#", "_") or file.endswith("~") or file.endswith(".swp"):
- continue
+ def periodical(self):
+ self.make_folders()
- if not os.access(file, os.X_OK):
- self.log_warning(_("Script not executable: [%s] %s") % (name, file))
+ folders = [entry for entry in os.listdir("scripts") \
+ if os.path.isdir(os.path.join("scripts", entry))]
- self.scripts[name].append(file)
- self.log_info(_("Registered script: [%s] %s") % (name, file))
+ for folder in folders:
+ self.scripts[folder] = []
+
+ dirname = os.path.join("scripts", folder)
+
+ for entry in os.listdir(dirname):
+ file = os.path.join(dirname, entry)
+
+ if not os.path.isfile(file):
+ continue
+
+ if file[0] in ("#", "_") or file.endswith("~") or file.endswith(".swp"):
+ continue
+
+ if not os.access(file, os.X_OK):
+ self.log_warning(_("Script `%s` is not executable") % entry)
+
+ self.scripts[folder].append(file)
+
+ script_names = map(os.path.basename, self.scripts[folder])
+ self.log_info(_("Activated %s scripts: %s")
+ % (folder, ", ".join(script_names) or None))
- @Expose
def call_cmd(self, command, *args, **kwargs):
- self.log_info(_("EXECUTE [%s] %s") % (os.path.dirname(command), args))
- call = map(encode, [command] + args)
+ call = [command] + args
+ self.log_debug("EXECUTE " + " ".join(call))
+ call = map(encode, call)
p = subprocess.Popen(call, bufsize=-1) #@NOTE: output goes to pyload
return p
@@ -93,12 +103,26 @@ class ExternalScripts(Addon):
@Expose
def call_script(self, folder, *args, **kwargs):
- for script in self.scripts[folder]:
+ scripts = self.scripts.get(folder)
+
+ if folder not in scripts:
+ self.log_debug("Folder `%s` not found" % folder)
+ return
+
+ scripts = self.scripts.get(folder)
+
+ if not scripts:
+ self.log_debug("No script found under folder `%s`" % folder)
+ return
+
+ self.log_info(_("Executing %s scripts...") % folder)
+
+ for file in scripts:
try:
- p = self.call_cmd(script, args)
+ p = self.call_cmd(file, args)
except Exception, e:
- self.log_error(_("Runtime error: %s") % script,
+ self.log_error(_("Runtime error: %s") % file,
e or _("Unknown error"))
else: