- add an aliases attribute as a lookup of aliasname to canonical name
of parameters - add support for no_log attribute per-parameter which will not log that information to syslog
This commit is contained in:
parent
f6e3583b9b
commit
c95848ae59
1 changed files with 19 additions and 3 deletions
|
@ -161,7 +161,9 @@ class AnsibleModule(object):
|
||||||
self.argument_spec = argument_spec
|
self.argument_spec = argument_spec
|
||||||
self.supports_check_mode = supports_check_mode
|
self.supports_check_mode = supports_check_mode
|
||||||
self.check_mode = False
|
self.check_mode = False
|
||||||
|
|
||||||
|
self.aliases = {}
|
||||||
|
|
||||||
if add_file_common_args:
|
if add_file_common_args:
|
||||||
self.argument_spec.update(FILE_COMMON_ARGUMENTS)
|
self.argument_spec.update(FILE_COMMON_ARGUMENTS)
|
||||||
|
|
||||||
|
@ -169,7 +171,8 @@ class AnsibleModule(object):
|
||||||
(self.params, self.args) = self._load_params()
|
(self.params, self.args) = self._load_params()
|
||||||
|
|
||||||
self._legal_inputs = [ 'CHECKMODE' ]
|
self._legal_inputs = [ 'CHECKMODE' ]
|
||||||
self._handle_aliases()
|
|
||||||
|
self.aliases = self._handle_aliases()
|
||||||
|
|
||||||
if check_invalid_arguments:
|
if check_invalid_arguments:
|
||||||
self._check_invalid_arguments()
|
self._check_invalid_arguments()
|
||||||
|
@ -460,6 +463,7 @@ class AnsibleModule(object):
|
||||||
|
|
||||||
|
|
||||||
def _handle_aliases(self):
|
def _handle_aliases(self):
|
||||||
|
aliases_results = {} #alias:canon
|
||||||
for (k,v) in self.argument_spec.iteritems():
|
for (k,v) in self.argument_spec.iteritems():
|
||||||
self._legal_inputs.append(k)
|
self._legal_inputs.append(k)
|
||||||
aliases = v.get('aliases', None)
|
aliases = v.get('aliases', None)
|
||||||
|
@ -474,8 +478,11 @@ class AnsibleModule(object):
|
||||||
self.fail_json(msg='internal error: aliases must be a list')
|
self.fail_json(msg='internal error: aliases must be a list')
|
||||||
for alias in aliases:
|
for alias in aliases:
|
||||||
self._legal_inputs.append(alias)
|
self._legal_inputs.append(alias)
|
||||||
|
aliases_results[alias] = k
|
||||||
if alias in self.params:
|
if alias in self.params:
|
||||||
self.params[k] = self.params[alias]
|
self.params[k] = self.params[alias]
|
||||||
|
|
||||||
|
return aliases_results
|
||||||
|
|
||||||
def _check_for_check_mode(self):
|
def _check_for_check_mode(self):
|
||||||
for (k,v) in self.params.iteritems():
|
for (k,v) in self.params.iteritems():
|
||||||
|
@ -583,8 +590,17 @@ class AnsibleModule(object):
|
||||||
# Sanitize possible password argument when logging.
|
# Sanitize possible password argument when logging.
|
||||||
log_args = dict()
|
log_args = dict()
|
||||||
passwd_keys = ['password', 'login_password']
|
passwd_keys = ['password', 'login_password']
|
||||||
|
|
||||||
for param in self.params:
|
for param in self.params:
|
||||||
if param in passwd_keys:
|
no_log = False
|
||||||
|
if self.aliases:
|
||||||
|
canon = self.aliases.get(param, param)
|
||||||
|
arg_opts = self.argument_spec[canon]
|
||||||
|
no_log = arg_opts.get('no_log', False)
|
||||||
|
|
||||||
|
if no_log:
|
||||||
|
log_args[param] = 'NOT_LOGGING_PARAMETER'
|
||||||
|
elif param in passwd_keys:
|
||||||
log_args[param] = 'NOT_LOGGING_PASSWORD'
|
log_args[param] = 'NOT_LOGGING_PASSWORD'
|
||||||
else:
|
else:
|
||||||
log_args[param] = self.params[param]
|
log_args[param] = self.params[param]
|
||||||
|
|
Loading…
Reference in a new issue