1
0
Fork 0
mirror of https://github.com/ansible-collections/community.general.git synced 2024-09-14 20:13:21 +02:00
This commit is contained in:
Matt Wright 2012-08-08 10:35:07 -04:00
parent 4de0e5de54
commit 0116e53e48

View file

@ -1,4 +1,23 @@
#!/usr/bin/python #!/usr/bin/python
# -*- coding: utf-8 -*-
# (c) 2012, Matt Wright <matt@nobien.net>
#
# This file is part of Ansible
#
# Ansible is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# Ansible is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with Ansible. If not, see <http://www.gnu.org/licenses/>.
#
PIP = None PIP = None
VIRTUALENV = None VIRTUALENV = None
@ -46,6 +65,10 @@ def _is_package_installed(name, version=None):
return _get_full_name(name, version).lower() in status_stdout.lower() return _get_full_name(name, version).lower() in status_stdout.lower()
def _did_install(out):
return 'Successfully installed' in out
def _run(cmd): def _run(cmd):
# returns (rc, stdout, stderr) from shell command # returns (rc, stdout, stderr) from shell command
process = subprocess.Popen(cmd, stdout=subprocess.PIPE, process = subprocess.Popen(cmd, stdout=subprocess.PIPE,
@ -65,10 +88,6 @@ def main():
module = AnsibleModule(argument_spec=arg_spec) module = AnsibleModule(argument_spec=arg_spec)
global PIP
global VIRTUALENV
global ENV
rc = 0 rc = 0
err = '' err = ''
out = '' out = ''
@ -93,16 +112,16 @@ def main():
if state == 'latest' and version is not None: if state == 'latest' and version is not None:
module.fail_json(msg='If `state` is set to `latest` the `version` ' module.fail_json(msg='If `state` is set to `latest` the `version` '
'paramater must not be specified.') 'parameter must not be specified.')
if state == 'latest' and requirements is not None: if state == 'latest' and requirements is not None:
module.fail_json(msg='If `state` is set to `latest` the `requirements` ' module.fail_json(msg='If `state` is set to `latest` the `requirements` '
'paramater must not be specified.') 'parameter must not be specified.')
if name is not None and '==' in name: if name is not None and '==' in name:
module.fail_json(msg='It looks like you specified the version number ' module.fail_json(msg='It looks like you specified the version number '
'in the library name. Use the `version` parameter ' 'in the library name. Use the `version` parameter '
'to specify versio instead') 'to specify version instead')
if version is not None and name is None: if version is not None and name is None:
module.fail_json(msg='The `version` parameter must be used with the ' module.fail_json(msg='The `version` parameter must be used with the '
@ -131,11 +150,8 @@ def main():
out += out_pip out += out_pip
err += err_pip err += err_pip
def did_install(out): changed = ((_did_install(out) and state == 'present') or
return 'Successfully installed' in out (not _did_install(out) and state == 'absent'))
changed = ((did_install(out) and state == 'present') or
(not did_install(out) and state == 'absent'))
if name and state == 'latest': if name and state == 'latest':
cmd = '%s %s %s --upgrade' % (PIP, command_map[state], name) cmd = '%s %s %s --upgrade' % (PIP, command_map[state], name)