mirror of https://github.com/ansible/ansible.git
allow modules to set custom stats (#18946)
can be per run or per host, also aggregate or not set_stats action plugin as reference implementation added doc stub display stats in calblack made custom stats showing configurablepull/19957/head
parent
1154aca746
commit
08e0f6ada5
@ -0,0 +1,69 @@
|
|||||||
|
#!/usr/bin/python
|
||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Copyright 2016 Ansible RedHat, Inc
|
||||||
|
#
|
||||||
|
# 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/>.
|
||||||
|
|
||||||
|
ANSIBLE_METADATA = {'status': ['preview'],
|
||||||
|
'supported_by': 'community',
|
||||||
|
'version': '1.0'}
|
||||||
|
|
||||||
|
DOCUMENTATION = '''
|
||||||
|
---
|
||||||
|
author: "Brian Coca (@bcoca)"
|
||||||
|
module: set_stats
|
||||||
|
short_description: Set stats for the current ansible run
|
||||||
|
description:
|
||||||
|
- This module allows setting/accumulating stats on the current ansible run, either per host of for all hosts in the run.
|
||||||
|
options:
|
||||||
|
data:
|
||||||
|
description:
|
||||||
|
- A dictionary of which each key represents a stat (or variable) you want to keep track of
|
||||||
|
required: true
|
||||||
|
per_host:
|
||||||
|
description:
|
||||||
|
- boolean that indicates if the stats is per host or for all hosts in the run.
|
||||||
|
required: no
|
||||||
|
default: no
|
||||||
|
aggregate:
|
||||||
|
description:
|
||||||
|
- boolean that indicates if the provided value is aggregated to the existing stat C(yes) or will replace it C(no)
|
||||||
|
required: no
|
||||||
|
default: yes
|
||||||
|
version_added: "2.3"
|
||||||
|
'''
|
||||||
|
|
||||||
|
EXAMPLES = '''
|
||||||
|
# Aggregating packages_installed stat per host
|
||||||
|
- set_stats:
|
||||||
|
data:
|
||||||
|
packages_installed: 31
|
||||||
|
|
||||||
|
# Aggregating random stats for all hosts using complex arguments
|
||||||
|
- set_stats:
|
||||||
|
data:
|
||||||
|
one_stat: 11
|
||||||
|
other_stat: "{{ local_var * 2 }}"
|
||||||
|
another_stat: "{{ some_registered_var.results | map(attribute='ansible_facts.some_fact') | list }}"
|
||||||
|
per_host: no
|
||||||
|
|
||||||
|
|
||||||
|
# setting stats (not aggregating)
|
||||||
|
- set_stats:
|
||||||
|
data:
|
||||||
|
the_answer: 42
|
||||||
|
aggregate: no
|
||||||
|
'''
|
@ -0,0 +1,73 @@
|
|||||||
|
# Copyright 2016 Ansible (RedHat, Inc)
|
||||||
|
#
|
||||||
|
# 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/>.
|
||||||
|
|
||||||
|
from __future__ import (absolute_import, division, print_function)
|
||||||
|
__metaclass__ = type
|
||||||
|
|
||||||
|
from ansible.compat.six import iteritems, string_types
|
||||||
|
from ansible.constants import mk_boolean as boolean
|
||||||
|
from ansible.plugins.action import ActionBase
|
||||||
|
from ansible.utils.vars import isidentifier
|
||||||
|
|
||||||
|
class ActionModule(ActionBase):
|
||||||
|
|
||||||
|
TRANSFERS_FILES = False
|
||||||
|
|
||||||
|
#TODO: document this in non-empty set_stats.py module
|
||||||
|
def run(self, tmp=None, task_vars=None):
|
||||||
|
if task_vars is None:
|
||||||
|
task_vars = dict()
|
||||||
|
|
||||||
|
result = super(ActionModule, self).run(tmp, task_vars)
|
||||||
|
|
||||||
|
stats = {'data': {}, 'per_host': False, 'aggregate': True}
|
||||||
|
|
||||||
|
if self._task.args:
|
||||||
|
data = self._task.args.get('data', {})
|
||||||
|
|
||||||
|
if not isinstance(data, dict):
|
||||||
|
data = self._templar.template(data, convert_bare=False, fail_on_undefined=True)
|
||||||
|
|
||||||
|
if not isinstance(data, dict):
|
||||||
|
result['failed'] = True
|
||||||
|
result['msg'] = "The 'data' option needs to be a dictionary/hash"
|
||||||
|
return result
|
||||||
|
|
||||||
|
# set boolean options, defaults are set above in stats init
|
||||||
|
for opt in ['per_host', 'aggregate']:
|
||||||
|
val = self._task.args.get(opt, None)
|
||||||
|
if val is not None:
|
||||||
|
if not isinstance(val, bool):
|
||||||
|
stats[opt] = boolean(self._templar.template(val))
|
||||||
|
else:
|
||||||
|
stats[opt] = val
|
||||||
|
|
||||||
|
for (k, v) in iteritems(data):
|
||||||
|
|
||||||
|
k = self._templar.template(k)
|
||||||
|
|
||||||
|
if not isidentifier(k):
|
||||||
|
result['failed'] = True
|
||||||
|
result['msg'] = "The variable name '%s' is not valid. Variables must start with a letter or underscore character, and contain only letters, numbers and underscores." % k
|
||||||
|
return result
|
||||||
|
|
||||||
|
stats['data'][k] = self._templar.template(v)
|
||||||
|
|
||||||
|
result['changed'] = False
|
||||||
|
result['ansible_stats'] = stats
|
||||||
|
|
||||||
|
return result
|
Loading…
Reference in New Issue