@ -59,6 +59,9 @@ EXAMPLES = '''
# Specify the default flavour to avoid ambiguity errors
# Specify the default flavour to avoid ambiguity errors
- openbsd_pkg : name = vim - - state = present
- openbsd_pkg : name = vim - - state = present
# Make sure all packages are upgraded
- openbsd_pkg : upgrade = yes
'''
'''
# Control if we write debug information to syslog.
# Control if we write debug information to syslog.
@ -266,8 +269,8 @@ def package_absent(name, installed_state, module):
return ( rc , stdout , stderr , changed )
return ( rc , stdout , stderr , changed )
# Function used to parse the package name based on packages-specs(7)
# Function used to parse the package name based on packages-specs(7) .
# The general name structure is "stem-version[-flavors]"
# The general name structure is "stem-version[-flavors]" .
def parse_package_name ( name , pkg_spec , module ) :
def parse_package_name ( name , pkg_spec , module ) :
# Do some initial matches so we can base the more advanced regex on that.
# Do some initial matches so we can base the more advanced regex on that.
version_match = re . search ( " -[0-9] " , name )
version_match = re . search ( " -[0-9] " , name )
@ -321,20 +324,55 @@ def parse_package_name(name, pkg_spec, module):
if match :
if match :
module . fail_json ( msg = " Trailing dash in flavor: " + pkg_spec [ ' flavor ' ] )
module . fail_json ( msg = " Trailing dash in flavor: " + pkg_spec [ ' flavor ' ] )
# Function used for upgrading all installed packages.
def upgrade_packages ( module ) :
if module . check_mode :
upgrade_cmd = ' pkg_add -Imnu '
else :
upgrade_cmd = ' pkg_add -Imu '
# Attempt to upgrade all packages.
rc , stdout , stderr = execute_command ( " %s " % upgrade_cmd , module )
# Try to find any occurance of a package changing version like:
# "bzip2-1.0.6->1.0.6p0: ok".
match = re . search ( " \ W \ w.+->.+: ok \ W " , stdout )
if match :
if module . check_mode :
module . exit_json ( changed = True )
changed = True
else :
changed = False
# It seems we can not trust the return value, so depend on the presence of
# stderr to know if something failed.
if stderr :
rc = 1
else :
rc = 0
return ( rc , stdout , stderr , changed )
# ===========================================
# ===========================================
# Main control flow
# Main control flow .
def main ( ) :
def main ( ) :
module = AnsibleModule (
module = AnsibleModule (
argument_spec = dict (
argument_spec = dict (
name = dict ( required = True ) ,
name = dict ( ) ,
state = dict ( required = True , choices = [ ' absent ' , ' installed ' , ' latest ' , ' present ' , ' removed ' ] ) ,
state = dict ( choices = [ ' absent ' , ' installed ' , ' latest ' , ' present ' , ' removed ' ] ) ,
upgrade = dict ( choices = [ ' yes ' ] ) ,
) ,
) ,
mutually_exclusive = [ [ ' name ' , ' upgrade ' ] ] ,
required_one_of = [ [ ' name ' , ' upgrade ' ] ] ,
supports_check_mode = True
supports_check_mode = True
)
)
name = module . params [ ' name ' ]
name = module . params [ ' name ' ]
state = module . params [ ' state ' ]
state = module . params [ ' state ' ]
upgrade = module . params [ ' upgrade ' ]
rc = 0
rc = 0
stdout = ' '
stdout = ' '
@ -342,21 +380,31 @@ def main():
result = { }
result = { }
result [ ' name ' ] = name
result [ ' name ' ] = name
result [ ' state ' ] = state
result [ ' state ' ] = state
result [ ' upgrade ' ] = upgrade
# Parse package name and put results in the pkg_spec dictionary.
pkg_spec = { }
if name :
parse_package_name ( name , pkg_spec , module )
if not state :
module . fail_json ( msg = " missing required arguments: state " )
# Get package state.
installed_state = get_package_state ( name , pkg_spec , module )
# Parse package name and put results in the pkg_spec dictionary.
pkg_spec = { }
# Perform requested action.
parse_package_name ( name , pkg_spec , module )
if state in [ ' installed ' , ' present ' ] :
( rc , stdout , stderr , changed ) = package_present ( name , installed_state , pkg_spec , module )
# Get package state.
elif state in [ ' absent ' , ' removed ' ] :
installed_state = get_package_state ( name , pkg_spec , module )
( rc , stdout , stderr , changed ) = package_absent ( name , installed_state , module )
elif state == ' latest ' :
# Perform requested action.
( rc , stdout , stderr , changed ) = package_latest ( name , installed_state , pkg_spec , module )
if state in [ ' installed ' , ' present ' ] :
( rc , stdout , stderr , changed ) = package_present ( name , installed_state , pkg_spec , module )
elif state in [ ' absent ' , ' removed ' ] :
( rc , stdout , stderr , changed ) = package_absent ( name , installed_state , module )
elif state == ' latest ' :
( rc , stdout , stderr , changed ) = package_latest ( name , installed_state , pkg_spec , module )
elif upgrade :
# Perform an upgrade of all installed packages.
( rc , stdout , stderr , changed ) = upgrade_packages ( module )
else :
module . fail_json ( msg = " Something is broken, you should never end up here " )
if rc != 0 :
if rc != 0 :
if stderr :
if stderr :
@ -368,6 +416,6 @@ def main():
module . exit_json ( * * result )
module . exit_json ( * * result )
# import module snippets
# Import module snippets.
from ansible . module_utils . basic import *
from ansible . module_utils . basic import *
main ( )
main ( )