mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
gconftool2 module (#19461)
* Pull #19267 broke sysctl module. Minor corrections * Commit of gconftool2 module
This commit is contained in:
parent
28a3a13656
commit
58b067532f
2 changed files with 248 additions and 1 deletions
247
lib/ansible/modules/system/gconftool2.py
Normal file
247
lib/ansible/modules/system/gconftool2.py
Normal file
|
@ -0,0 +1,247 @@
|
||||||
|
#!/usr/bin/python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# (c) 2016, Kenneth D. Evensen <kevensen@redhat.com>
|
||||||
|
#
|
||||||
|
# This file is part of Ansible (sort of)
|
||||||
|
#
|
||||||
|
# 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/>.
|
||||||
|
from ansible.module_utils.basic import AnsibleModule, BOOLEANS_TRUE
|
||||||
|
from ansible.module_utils.pycompat24 import get_exception
|
||||||
|
import subprocess
|
||||||
|
|
||||||
|
DOCUMENTATION = """
|
||||||
|
module: gconftool2
|
||||||
|
author:
|
||||||
|
- "Kenneth D. Evensen (@kevensen)"
|
||||||
|
short_description: Edit GNOME Configurations
|
||||||
|
description:
|
||||||
|
- Edit PAM service's type, control, module path and module arguments.
|
||||||
|
In order for a PAM rule to be modified, the type, control and
|
||||||
|
module_path must match an existing rule. See man(5) pam.d for details.
|
||||||
|
version_added: "2.3"
|
||||||
|
options:
|
||||||
|
key:
|
||||||
|
required: true
|
||||||
|
description:
|
||||||
|
- A GConf preference key is an element in the GConf repository
|
||||||
|
that corresponds to an application preference. See man gconftool-2(1)
|
||||||
|
value:
|
||||||
|
required: false
|
||||||
|
description:
|
||||||
|
- Preference keys typically have simple values such as strings,
|
||||||
|
integers, or lists of strings and integers. This is ignored if the state
|
||||||
|
is "get". See man gconftool-2(1)
|
||||||
|
value_type:
|
||||||
|
required: false
|
||||||
|
choices:
|
||||||
|
- int
|
||||||
|
- bool
|
||||||
|
- float
|
||||||
|
- string
|
||||||
|
description:
|
||||||
|
- The type of value being set. This is ignored if the state is "get".
|
||||||
|
state:
|
||||||
|
required: true
|
||||||
|
choices:
|
||||||
|
- get
|
||||||
|
- set
|
||||||
|
- unset
|
||||||
|
description:
|
||||||
|
- The action to take upon the key/value.
|
||||||
|
config_source:
|
||||||
|
required: false
|
||||||
|
description:
|
||||||
|
- Specify a configuration source to use rather than the default path.
|
||||||
|
See man gconftool-2(1)
|
||||||
|
direct:
|
||||||
|
required: false
|
||||||
|
choices: [ "yes", "no" ]
|
||||||
|
default: no
|
||||||
|
description:
|
||||||
|
- Access the config database directly, bypassing server. If direct is
|
||||||
|
specified then the config_source must be specified as well.
|
||||||
|
See man gconftool-2(1)
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
EXAMPLES = """
|
||||||
|
- name: Change the widget font to "Serif 12"
|
||||||
|
gconftool2:
|
||||||
|
key: "/desktop/gnome/interface/font_name"
|
||||||
|
value_type: "string"
|
||||||
|
value: "Serif 12"
|
||||||
|
"""
|
||||||
|
|
||||||
|
RETURN = '''
|
||||||
|
key:
|
||||||
|
description: The key specified in the module parameters
|
||||||
|
returned: success
|
||||||
|
type: string
|
||||||
|
sample: "/desktop/gnome/interface/font_name"
|
||||||
|
value_type:
|
||||||
|
description: The type of the value that was changed
|
||||||
|
returned: success
|
||||||
|
type: string
|
||||||
|
sample: "string"
|
||||||
|
value:
|
||||||
|
description: The value of the preference key after executing the module
|
||||||
|
returned: success
|
||||||
|
type: string
|
||||||
|
sample: "Serif 12"
|
||||||
|
...
|
||||||
|
'''
|
||||||
|
|
||||||
|
|
||||||
|
class GConf2Preference(object):
|
||||||
|
def __init__(self, ansible, key, value_type, value,
|
||||||
|
direct=False, config_source=""):
|
||||||
|
self.ansible = ansible
|
||||||
|
self.key = key
|
||||||
|
self.value_type = value_type
|
||||||
|
self.value = value
|
||||||
|
self.config_source = config_source
|
||||||
|
self.direct = direct
|
||||||
|
|
||||||
|
def value_already_set(self):
|
||||||
|
return False
|
||||||
|
|
||||||
|
def call(self, call_type):
|
||||||
|
config_source = ''
|
||||||
|
direct = ''
|
||||||
|
changed = False
|
||||||
|
out = ''
|
||||||
|
|
||||||
|
# If the configuration source is different from the default, create
|
||||||
|
# the argument
|
||||||
|
if self.config_source is not None and len(self.config_source) > 0:
|
||||||
|
config_source = "--config-source " + self.config_source
|
||||||
|
|
||||||
|
# If direct is true, create the argument
|
||||||
|
if self.direct:
|
||||||
|
direct = "--direct"
|
||||||
|
|
||||||
|
# Execute the call
|
||||||
|
try:
|
||||||
|
# If the call is "get", then we don't need as many parameters and
|
||||||
|
# we can ignore some
|
||||||
|
if call_type == 'get':
|
||||||
|
process = subprocess.Popen(["gconftool-2 --get " + self.key],
|
||||||
|
stdout=subprocess.PIPE,
|
||||||
|
stderr=subprocess.PIPE, shell=True)
|
||||||
|
# Otherwise, we will use all relevant parameters
|
||||||
|
else:
|
||||||
|
process = subprocess.Popen(["gconftool-2 " + direct + " " +
|
||||||
|
config_source + " --type " +
|
||||||
|
self.value_type + " --" +
|
||||||
|
call_type + " " + self.key + " " +
|
||||||
|
self.value], stdout=subprocess.PIPE,
|
||||||
|
stderr=subprocess.PIPE, shell=True)
|
||||||
|
# In either case, we will capture the output
|
||||||
|
out = process.stdout.read()
|
||||||
|
err = process.stderr.read()
|
||||||
|
|
||||||
|
if len(err) > 0:
|
||||||
|
self.ansible.fail_json(msg='gconftool-2 failed with error: %s'
|
||||||
|
% (str(err)))
|
||||||
|
else:
|
||||||
|
changed = True
|
||||||
|
|
||||||
|
except OSError:
|
||||||
|
self.ansible.fail_json(msg='gconftool-2 failed with and exception')
|
||||||
|
|
||||||
|
return changed, out.rstrip()
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
# Setup the Ansible module
|
||||||
|
module = AnsibleModule(
|
||||||
|
argument_spec=dict(
|
||||||
|
key=dict(required=True, default=None, type='str'),
|
||||||
|
value_type=dict(required=False,
|
||||||
|
choices=['int', 'bool',
|
||||||
|
'float', 'string'],
|
||||||
|
type='str'),
|
||||||
|
value=dict(required=False, default=None,
|
||||||
|
type='str'),
|
||||||
|
state=dict(required=True, default=None,
|
||||||
|
choices=['set', 'get', 'unset'],
|
||||||
|
type='str'),
|
||||||
|
direct=dict(required=False,
|
||||||
|
default=False, type='bool'),
|
||||||
|
config_source=dict(required=False,
|
||||||
|
default=None, type='str')
|
||||||
|
),
|
||||||
|
supports_check_mode=True
|
||||||
|
)
|
||||||
|
|
||||||
|
direct = False
|
||||||
|
# Assign module values to dictionary values
|
||||||
|
key = module.params['key']
|
||||||
|
value_type = module.params['value_type']
|
||||||
|
value = module.params['value']
|
||||||
|
state = module.params['state']
|
||||||
|
if module.params['direct'] in BOOLEANS_TRUE:
|
||||||
|
direct = True
|
||||||
|
config_source = module.params['config_source']
|
||||||
|
|
||||||
|
# Initialize some variables for later
|
||||||
|
change = False
|
||||||
|
new_value = ''
|
||||||
|
|
||||||
|
if state != "get":
|
||||||
|
if value is None or value == "":
|
||||||
|
module.fail_json(msg='State %s requires "value" to be set'
|
||||||
|
% str(state))
|
||||||
|
elif value_type is None or value_type == "":
|
||||||
|
module.fail_json(msg='State %s requires "value_type" to be set'
|
||||||
|
% str(state))
|
||||||
|
|
||||||
|
if direct and config_source is None:
|
||||||
|
module.fail_json(msg='If "direct" is "yes" then the ' +
|
||||||
|
'"config_source" must be specified')
|
||||||
|
elif not direct and config_source is not None:
|
||||||
|
module.fail_json(msg='If the "config_source" is specified ' +
|
||||||
|
'then "direct" must be "yes"')
|
||||||
|
|
||||||
|
# Create a gconf2 preference
|
||||||
|
gconf_pref = GConf2Preference(module, key, value_type,
|
||||||
|
value, direct, config_source)
|
||||||
|
# Now we get the current value
|
||||||
|
_, current_value = gconf_pref.call("get")
|
||||||
|
|
||||||
|
# Check if the current value equals the value we want to set. If not, make
|
||||||
|
# a change
|
||||||
|
if current_value != value:
|
||||||
|
# If check mode, we know a change would have occured.
|
||||||
|
if module.check_mode:
|
||||||
|
# So we will set the change to True
|
||||||
|
change = True
|
||||||
|
# And set the new_value to the value that would have been set
|
||||||
|
new_value = value
|
||||||
|
# If not check mode make the change.
|
||||||
|
else:
|
||||||
|
change, new_value = gconf_pref.call(state)
|
||||||
|
# If the value we want to set is the same as the current_value, we will
|
||||||
|
# set the new_value to the current_value for reporting
|
||||||
|
else:
|
||||||
|
new_value = current_value
|
||||||
|
|
||||||
|
facts = {}
|
||||||
|
facts['gconftool2'] = {'changed': change, 'key': key,
|
||||||
|
'value_type': value_type, 'value': new_value}
|
||||||
|
|
||||||
|
module.exit_json(changed=change, ansible_facts=facts)
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
|
@ -118,7 +118,7 @@ EXAMPLES = '''
|
||||||
import os
|
import os
|
||||||
import tempfile
|
import tempfile
|
||||||
import re
|
import re
|
||||||
from ansible.module_utils.basic import get_platform, AnsibleModule
|
from ansible.module_utils.basic import get_platform, AnsibleModule, BOOLEANS_TRUE, BOOLEANS_FALSE
|
||||||
|
|
||||||
class SysctlModule(object):
|
class SysctlModule(object):
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue