2015-01-09 16:37:31 +01:00
|
|
|
# (c) 2013, Michael DeHaan <michael.dehaan@gmail.com>
|
2017-09-19 16:49:07 +02:00
|
|
|
# (c) 2017 Ansible Project
|
|
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
2015-04-13 22:28:01 +02:00
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
2015-01-09 16:37:31 +01:00
|
|
|
|
2017-09-19 16:49:07 +02:00
|
|
|
DOCUMENTATION = """
|
|
|
|
lookup: random_choice
|
|
|
|
author: Michael DeHaan <michael.dehaan@gmail.com>
|
|
|
|
version_added: "1.1"
|
|
|
|
short_description: return random element from list
|
|
|
|
description:
|
|
|
|
- The 'random_choice' feature can be used to pick something at random. While it's not a load balancer (there are modules for those),
|
|
|
|
it can somewhat be used as a poor man's load balancer in a MacGyver like situation.
|
|
|
|
- At a more basic level, they can be used to add chaos and excitement to otherwise predictable automation environments.
|
|
|
|
"""
|
|
|
|
|
|
|
|
EXAMPLES = """
|
|
|
|
- name: Magic 8 ball for MUDs
|
|
|
|
debug:
|
|
|
|
msg: "{{ item }}"
|
|
|
|
with_random_choice:
|
|
|
|
- "go through the door"
|
|
|
|
- "drink from the goblet"
|
|
|
|
- "press the red button"
|
|
|
|
- "do nothing"
|
|
|
|
"""
|
|
|
|
|
|
|
|
RETURN = """
|
|
|
|
_raw:
|
|
|
|
description:
|
|
|
|
- random item
|
|
|
|
"""
|
2015-01-09 16:37:31 +01:00
|
|
|
import random
|
|
|
|
|
2017-07-31 17:44:53 +02:00
|
|
|
from ansible.errors import AnsibleError
|
|
|
|
from ansible.module_utils._text import to_native
|
2015-01-09 16:37:31 +01:00
|
|
|
from ansible.plugins.lookup import LookupBase
|
|
|
|
|
2017-06-02 13:14:11 +02:00
|
|
|
|
2015-01-09 16:37:31 +01:00
|
|
|
class LookupModule(LookupBase):
|
|
|
|
|
|
|
|
def run(self, terms, inject=None, **kwargs):
|
|
|
|
|
2017-07-31 17:44:53 +02:00
|
|
|
ret = terms
|
|
|
|
if terms:
|
|
|
|
try:
|
|
|
|
ret = [random.choice(terms)]
|
|
|
|
except Exception as e:
|
|
|
|
raise AnsibleError("Unable to choose random term: %s" % to_native(e))
|
|
|
|
|
|
|
|
return ret
|