From 025b52938eb449b48e6ac57254161ad4673ab79c Mon Sep 17 00:00:00 2001 From: ademmers Date: Mon, 12 Jun 2017 21:29:08 +0200 Subject: [PATCH] system/service module initctl location usage (#19712) * Call initctl version based on initctl's retrieved location * Remove the use of start/stop/restart in favor of initctl * Provide correct argument order for initctl usage --- lib/ansible/modules/system/service.py | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) diff --git a/lib/ansible/modules/system/service.py b/lib/ansible/modules/system/service.py index ea484e88cc..18478e6919 100644 --- a/lib/ansible/modules/system/service.py +++ b/lib/ansible/modules/system/service.py @@ -490,7 +490,7 @@ class LinuxService(Service): self.upstart_version = LooseVersion('0.0.0') try: version_re = re.compile(r'\(upstart (.*)\)') - rc,stdout,stderr = self.module.run_command('initctl version') + rc,stdout,stderr = self.module.run_command('%s version' % location['initctl']) if rc == 0: res = version_re.search(stdout) if res: @@ -498,9 +498,7 @@ class LinuxService(Service): except: pass # we'll use the default of 0.0.0 - if location.get('start', False): - # upstart -- rather than being managed by one command, start/stop/restart are actual commands - self.svc_cmd = '' + self.svc_cmd = location['initctl'] elif location.get('rc-service', False): # service is managed by OpenRC @@ -922,8 +920,13 @@ class LinuxService(Service): arguments = self.arguments if self.svc_cmd: if not self.svc_cmd.endswith("systemctl"): - # SysV and OpenRC take the form - svc_cmd = "%s %s" % (self.svc_cmd, self.name) + if self.svc_cmd.endswith("initctl"): + # initctl commands take the form + svc_cmd = self.svc_cmd + arguments = "%s %s" % (self.name, arguments) + else: + # SysV and OpenRC take the form + svc_cmd = "%s %s" % (self.svc_cmd, self.name) else: # systemd commands take the form svc_cmd = self.svc_cmd