Service module now knows a little more about systemd. This module is

really due for some refactoring, but telling how a service is managed is
a little fuzzy anyway.  on a systemd system typoing the service will now
give you a rather systemd specific error which is somewhat suboptimal.
This commit is contained in:
Michael DeHaan 2013-02-24 11:50:39 -05:00
parent 4be3b06842
commit 596c98320a

View file

@ -366,7 +366,7 @@ class LinuxService(Service):
elif location.get('systemctl', None): elif location.get('systemctl', None):
# service is managed by systemd # service is managed by systemd
self.enable_cmd = location['systemctl'] self.enable_cmd = location['systemctl']
# Locate a tool for runtime service management (start, stop etc.) # Locate a tool for runtime service management (start, stop etc.)
self.svc_cmd = '' self.svc_cmd = ''
if location.get('service', None) and os.path.exists("/etc/init.d/%s" % self.name): if location.get('service', None) and os.path.exists("/etc/init.d/%s" % self.name):
@ -382,6 +382,11 @@ class LinuxService(Service):
if os.path.isfile(initscript): if os.path.isfile(initscript):
self.svc_initscript = initscript self.svc_initscript = initscript
# couldn't find anything yet, assume systemd
if self.svc_initscript is None:
if location.get('systemctl'):
self.svc_cmd = location['systemctl']
if self.svc_cmd is None and not self.svc_initscript: if self.svc_cmd is None and not self.svc_initscript:
self.module.fail_json(msg='cannot find \'service\' binary or init script for service, aborting') self.module.fail_json(msg='cannot find \'service\' binary or init script for service, aborting')
@ -444,8 +449,9 @@ class LinuxService(Service):
if self.enable_cmd is None: if self.enable_cmd is None:
self.module.fail_json(msg='unable to find enable binary') self.module.fail_json(msg='unable to find enable binary')
# FIXME: we use chkconfig to decide whether to run the command here, but if we don't # FIXME: we use chkconfig or systemctl
# have chkconfig we need similar code for updates-rc.d and systemd. # to decide whether to run the command here but need something
# similar for upstart
if self.enable_cmd.endswith("chkconfig"): if self.enable_cmd.endswith("chkconfig"):
(rc, out, err) = self.execute_command("%s --list %s" % (self.enable_cmd, self.name)) (rc, out, err) = self.execute_command("%s --list %s" % (self.enable_cmd, self.name))
@ -457,6 +463,13 @@ class LinuxService(Service):
elif not self.enable and ( "3:off" in out and "5:off" in out ): elif not self.enable and ( "3:off" in out and "5:off" in out ):
return return
if self.enable_cmd.endswith("systemctl"):
(rc, out, err) = self.execute_command("%s is-enabled %s.service" % (self.enable_cmd, self.name))
if self.enable and rc == 0:
return
elif not self.enable and rc == 1:
return
# we change argument depending on real binary used # we change argument depending on real binary used
# update-rc.d wants enable/disable while # update-rc.d wants enable/disable while
# chkconfig wants on/off # chkconfig wants on/off
@ -488,8 +501,13 @@ class LinuxService(Service):
# Decide what command to run # Decide what command to run
svc_cmd = '' svc_cmd = ''
if self.svc_cmd: if self.svc_cmd:
# SysV or systemd if not self.svc_cmd.endswith("systemctl"):
svc_cmd = "%s %s" % (self.svc_cmd, self.name) # SysV or systemd take the form <cmd> <name> <action>
svc_cmd = "%s %s" % (self.svc_cmd, self.name)
else:
# systemd commands take the form <cmd> <action> <name>
svc_cmd = self.svc_cmd
self.arguments = "%s %s" % (self.name, self.arguments)
elif self.svc_initscript: elif self.svc_initscript:
# upstart # upstart
svc_cmd = "%s" % self.svc_initscript svc_cmd = "%s" % self.svc_initscript