Merge pull request #970 from mattupstate/devel
Improve apt_repository and supervisorctl
This commit is contained in:
commit
a454db5345
2 changed files with 21 additions and 6 deletions
|
@ -39,6 +39,8 @@ def _find_binary(module):
|
|||
'%s' % binaries)
|
||||
|
||||
def _run(cmd):
|
||||
if platform.dist()[0] == 'debian' or float(platform.dist()[1]) >= 11.10:
|
||||
cmd = cmd + ' -y'
|
||||
# returns (rc, stdout, stderr) from shell command
|
||||
process = subprocess.Popen(cmd, stdout=subprocess.PIPE,
|
||||
stderr=subprocess.PIPE, shell=True)
|
||||
|
@ -72,9 +74,6 @@ def main():
|
|||
|
||||
cmd = '%s "%s"' % (add_apt_repository, repo)
|
||||
|
||||
if platform.dist()[0] == 'debian' or float(platform.dist()[1]) >= 11.10:
|
||||
cmd = cmd + ' -y'
|
||||
|
||||
rc, out, err = _run(cmd)
|
||||
|
||||
changed = rc == 0 and not existed
|
||||
|
|
|
@ -27,6 +27,9 @@ def _find_supervisorctl():
|
|||
if os.path.exists(e):
|
||||
return e
|
||||
|
||||
def _is_present(name):
|
||||
rc, out, err = _run('%s status' % _find_supervisorctl())
|
||||
return name in out
|
||||
|
||||
def _is_running(name):
|
||||
rc, out, err = _run('%s status %s' % (_find_supervisorctl(), name))
|
||||
|
@ -44,7 +47,7 @@ def _run(cmd):
|
|||
def main():
|
||||
arg_spec = dict(
|
||||
name=dict(required=True),
|
||||
state=dict(required=True, choices=['started', 'restarted', 'stopped'])
|
||||
state=dict(required=True, choices=['present', 'started', 'restarted', 'stopped'])
|
||||
)
|
||||
|
||||
module = AnsibleModule(argument_spec=arg_spec)
|
||||
|
@ -57,6 +60,20 @@ def main():
|
|||
if SUPERVISORCTL is None:
|
||||
module.fail_json(msg='supervisorctl is not installed')
|
||||
|
||||
present = _is_present(name)
|
||||
|
||||
if state == 'present':
|
||||
if not present:
|
||||
_run('%s reread' % SUPERVISORCTL)
|
||||
rc, out, err = _run('%s add %s' % (SUPERVISORCTL, name))
|
||||
|
||||
if '%s: added process group' % name in out:
|
||||
module.exit_json(changed=True, name=name, state=state)
|
||||
else:
|
||||
module.fail_json(msg=out, name=name, state=state)
|
||||
|
||||
module.exit_json(changed=False, name=name, state=state)
|
||||
|
||||
running = _is_running(name)
|
||||
|
||||
if running and state == 'started':
|
||||
|
@ -71,7 +88,7 @@ def main():
|
|||
module.fail_json(msg=out)
|
||||
|
||||
elif running and state == 'restarted':
|
||||
rc, out, err = _run('%s update' % SUPERVISORCTL)
|
||||
rc, out, err = _run('%s update %s' % (SUPERVISORCTL, name))
|
||||
rc, out, err = _run('%s restart %s' % (SUPERVISORCTL, name))
|
||||
|
||||
if '%s: stopped' % name in out and '%s: started' % name in out:
|
||||
|
@ -80,7 +97,6 @@ def main():
|
|||
module.fail_json(msg=out)
|
||||
|
||||
elif not running and state == 'started':
|
||||
rc, out, err = _run('%s update' % SUPERVISORCTL)
|
||||
rc, out, err = _run('%s start %s' % (SUPERVISORCTL, name))
|
||||
|
||||
if '%s: started' % name in out:
|
||||
|
|
Loading…
Reference in a new issue