summaryrefslogtreecommitdiffstats
path: root/src/lib/Bcfg2/Server/Plugins/Trigger.py
diff options
context:
space:
mode:
authorChris St. Pierre <chris.a.st.pierre@gmail.com>2012-09-21 13:55:05 -0400
committerChris St. Pierre <chris.a.st.pierre@gmail.com>2012-09-25 11:58:47 -0400
commitdd28e90f183972cc2a395094ce3e3f72e861953f (patch)
treedfe10fd66e0535763d953333ed49f6467762fbd6 /src/lib/Bcfg2/Server/Plugins/Trigger.py
parenteec8f653c0235bde8d3a754802a4485f0d542ea3 (diff)
downloadbcfg2-dd28e90f183972cc2a395094ce3e3f72e861953f.tar.gz
bcfg2-dd28e90f183972cc2a395094ce3e3f72e861953f.tar.bz2
bcfg2-dd28e90f183972cc2a395094ce3e3f72e861953f.zip
run pylint for errors on almost everything, full runs on some selected stuff
Diffstat (limited to 'src/lib/Bcfg2/Server/Plugins/Trigger.py')
-rw-r--r--src/lib/Bcfg2/Server/Plugins/Trigger.py12
1 files changed, 9 insertions, 3 deletions
diff --git a/src/lib/Bcfg2/Server/Plugins/Trigger.py b/src/lib/Bcfg2/Server/Plugins/Trigger.py
index 313a1bf03..7279edfed 100644
--- a/src/lib/Bcfg2/Server/Plugins/Trigger.py
+++ b/src/lib/Bcfg2/Server/Plugins/Trigger.py
@@ -1,9 +1,14 @@
+""" Trigger is a plugin that calls external scripts (on the server) """
+
import os
import pipes
import Bcfg2.Server.Plugin
from subprocess import Popen, PIPE
+
class TriggerFile(Bcfg2.Server.Plugin.FileBacked):
+ """ Representation of a trigger script file """
+
def HandleEvent(self, event=None):
return
@@ -25,6 +30,8 @@ class Trigger(Bcfg2.Server.Plugin.Plugin,
self.core.fam)
def async_run(self, args):
+ """ Run the trigger script asynchronously in a forked process
+ """
pid = os.fork()
if pid:
os.waitpid(pid, 0)
@@ -34,15 +41,14 @@ class Trigger(Bcfg2.Server.Plugin.Plugin,
self.debug_log("Running %s" % " ".join(pipes.quote(a)
for a in args))
proc = Popen(args, stdin=PIPE, stdout=PIPE, stderr=PIPE)
- (out, err) = proc.communicate()
+ err = proc.communicate()[1]
rv = proc.wait()
if rv != 0:
self.logger.error("Trigger: Error running %s (%s): %s" %
(args[0], rv, err))
elif err:
self.debug_log("Trigger: Error: %s" % err)
- os._exit(0)
-
+ os._exit(0) # pylint: disable=W0212
def end_client_run(self, metadata):
args = [metadata.hostname, '-p', metadata.profile, '-g',