made changes as per feedback:

- field names are more consistent with debconf
- values are now 'booleanized' or accepted as list/set objects when
  pertinent
- updated docs to reflect all of the above and debconf cli tools
  required
reviewable/pr18780/r1
Brian Coca 11 years ago
parent c11fbd54e1
commit 4b0c2d839e

@ -26,9 +26,10 @@ DOCUMENTATION = '''
module: debconf module: debconf
short_description: Configure a .deb package short_description: Configure a .deb package
description: description:
- Configure a .deb package using debconf-set-selections - Configure a .deb package using debconf-set-selections.
version_added: "1.5" version_added: "1.5"
notes: notes:
- This module requires the command line debconf tools.
- A number of questions have to be answered (depending on the package). - A number of questions have to be answered (depending on the package).
Use 'debconf-show <package>' on any Debian or derivative with the package Use 'debconf-show <package>' on any Debian or derivative with the package
installed to see questions/settings available. installed to see questions/settings available.
@ -39,12 +40,12 @@ options:
required: true required: true
default: null default: null
aliases: ['pkg'] aliases: ['pkg']
setting: question:
description: description:
- A debconf configuration setting - A debconf configuration setting
required: false required: false
default: null default: null
aliases: ['question', 'selection'] aliases: ['setting', 'selection']
vtype: vtype:
description: description:
- The type of the value supplied - The type of the value supplied
@ -70,10 +71,10 @@ author: Brian Coca
EXAMPLES = ''' EXAMPLES = '''
# Set default locale to fr_FR.UTF-8 # Set default locale to fr_FR.UTF-8
debconf: name=locales setting='locales/default_environment_locale' value=fr_FR.UTF-8 debconf: name=locales question='locales/default_environment_locale' value=fr_FR.UTF-8
# set to generate locales: # set to generate locales:
debconf: name=locales setting='locales/locales_to_be_generated value='en_US.UTF-8 UTF-8, fr_FR.UTF-8 UTF-8' debconf: name=locales question='locales/locales_to_be_generated value='en_US.UTF-8 UTF-8, fr_FR.UTF-8 UTF-8'
# Accept oracle license # Accept oracle license
debconf: name='oracle-java7-installer' question='shared/accepted-oracle-license-v1-1' value='true' vtype='select' debconf: name='oracle-java7-installer' question='shared/accepted-oracle-license-v1-1' value='true' vtype='select'
@ -118,7 +119,7 @@ def main():
module = AnsibleModule( module = AnsibleModule(
argument_spec = dict( argument_spec = dict(
name = dict(required=True, aliases=['pkg'], type='str'), name = dict(required=True, aliases=['pkg'], type='str'),
setting = dict(required=False, aliases=['question', 'selection'], type='str'), question = dict(required=False, aliases=['setting', 'selection'], type='str'),
vtype = dict(required=False, type='str', choices=['string', 'boolean', 'select', 'multiselect', 'note', 'text', 'password', 'title']), vtype = dict(required=False, type='str', choices=['string', 'boolean', 'select', 'multiselect', 'note', 'text', 'password', 'title']),
value= dict(required=False, type='str'), value= dict(required=False, type='str'),
unseen = dict(required=False, type='bool'), unseen = dict(required=False, type='bool'),
@ -128,7 +129,7 @@ def main():
#TODO: enable passing array of optionas and/or debconf file from get-selections dump #TODO: enable passing array of optionas and/or debconf file from get-selections dump
pkg = module.params["name"] pkg = module.params["name"]
question = module.params["setting"] question = module.params["question"]
vtype = module.params["vtype"] vtype = module.params["vtype"]
value = module.params["value"] value = module.params["value"]
unseen = module.params["unseen"] unseen = module.params["unseen"]
@ -139,6 +140,12 @@ def main():
changed = False changed = False
msg = "" msg = ""
# Adjust value field if needed
if vtype == 'boolean':
value = boolean(value)
elif vtype == 'multiselect' and (isisntance(value, list) or isinstace(value, set)):
value = ','.join(value)
if question is not None: if question is not None:
if not question in prev or prev[question] != value: if not question in prev or prev[question] != value:
changed = True changed = True

Loading…
Cancel
Save