summaryrefslogtreecommitdiffstats
path: root/src/lib/Bcfg2/Client/Tools/Systemd.py
diff options
context:
space:
mode:
authorChris St. Pierre <chris.a.st.pierre@gmail.com>2013-02-12 16:02:24 -0500
committerChris St. Pierre <chris.a.st.pierre@gmail.com>2013-02-14 14:57:04 -0500
commit43984bc5ebc59bd8c5890ed6ba3de162e6698dcc (patch)
treed9e972b160d5d5033537495e9f507cfe043483c3 /src/lib/Bcfg2/Client/Tools/Systemd.py
parentd526c8745b61c1977b775cfe750a86c51dd6a9f3 (diff)
downloadbcfg2-43984bc5ebc59bd8c5890ed6ba3de162e6698dcc.tar.gz
bcfg2-43984bc5ebc59bd8c5890ed6ba3de162e6698dcc.tar.bz2
bcfg2-43984bc5ebc59bd8c5890ed6ba3de162e6698dcc.zip
better Executor class for client tools
Diffstat (limited to 'src/lib/Bcfg2/Client/Tools/Systemd.py')
-rw-r--r--src/lib/Bcfg2/Client/Tools/Systemd.py31
1 files changed, 11 insertions, 20 deletions
diff --git a/src/lib/Bcfg2/Client/Tools/Systemd.py b/src/lib/Bcfg2/Client/Tools/Systemd.py
index 43eca2eac..027d91c71 100644
--- a/src/lib/Bcfg2/Client/Tools/Systemd.py
+++ b/src/lib/Bcfg2/Client/Tools/Systemd.py
@@ -5,6 +5,7 @@
import Bcfg2.Client.Tools
import Bcfg2.Client.XML
+
class Systemd(Bcfg2.Client.Tools.SvcTool):
"""Systemd support for Bcfg2."""
name = 'Systemd'
@@ -21,35 +22,25 @@ class Systemd(Bcfg2.Client.Tools.SvcTool):
return True
cmd = "/bin/systemctl status %s.service " % (entry.get('name'))
- raw = ''.join(self.cmd.run(cmd)[1])
+ rv = self.cmd.run(cmd)
- if raw.find('Loaded: error') >= 0:
+ if 'Loaded: error' in rv.stdout:
entry.set('current_status', 'off')
- status = False
-
- elif raw.find('Active: active') >= 0:
+ return False
+ elif 'Active: active' in rv.stdout:
entry.set('current_status', 'on')
- if entry.get('status') == 'off':
- status = False
- else:
- status = True
-
+ return entry.get('status') == 'on'
else:
entry.set('current_status', 'off')
- if entry.get('status') == 'on':
- status = False
- else:
- status = True
-
- return status
+ return entry.get('status') == 'off'
def InstallService(self, entry):
"""Install Service entry."""
if entry.get('status') == 'on':
- rv = self.cmd.run(self.get_svc_command(entry, 'enable'))[0] == 0
- rv &= self.cmd.run(self.get_svc_command(entry, 'start'))[0] == 0
+ rv = self.cmd.run(self.get_svc_command(entry, 'enable')).success
+ rv &= self.cmd.run(self.get_svc_command(entry, 'start')).success
else:
- rv = self.cmd.run(self.get_svc_command(entry, 'stop'))[0] == 0
- rv &= self.cmd.run(self.get_svc_command(entry, 'disable'))[0] == 0
+ rv = self.cmd.run(self.get_svc_command(entry, 'stop')).success
+ rv &= self.cmd.run(self.get_svc_command(entry, 'disable')).success
return rv