mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
new redis lookup (#33883)
* new redis lookup deprecated redis_kv * typo fix
This commit is contained in:
parent
67a8ff47aa
commit
1a7c096954
2 changed files with 115 additions and 0 deletions
|
@ -9,6 +9,10 @@ DOCUMENTATION = """
|
||||||
author: Jan-Piet Mens <jpmens(at)gmail.com>
|
author: Jan-Piet Mens <jpmens(at)gmail.com>
|
||||||
version_added: "0.9"
|
version_added: "0.9"
|
||||||
short_description: fetch data from Redis
|
short_description: fetch data from Redis
|
||||||
|
deprecated:
|
||||||
|
why: This lookup uses options intermingled with terms which blurs the interface between settings and data
|
||||||
|
version: '2.9'
|
||||||
|
alternative: new 'redis' lookup
|
||||||
description:
|
description:
|
||||||
- this looup returns a list of items given to it, if any of the top level items is also a list it will flatten it, but it will not recurse
|
- this looup returns a list of items given to it, if any of the top level items is also a list it will flatten it, but it will not recurse
|
||||||
requirements:
|
requirements:
|
111
lib/ansible/plugins/lookup/redis.py
Normal file
111
lib/ansible/plugins/lookup/redis.py
Normal file
|
@ -0,0 +1,111 @@
|
||||||
|
# (c) 2012, Jan-Piet Mens <jpmens(at)gmail.com>
|
||||||
|
# (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 = """
|
||||||
|
lookup: redis
|
||||||
|
author:
|
||||||
|
- Jan-Piet Mens (@jpmens) <jpmens(at)gmail.com>
|
||||||
|
- Ansible Core
|
||||||
|
version_added: "0.9"
|
||||||
|
short_description: fetch data from Redis
|
||||||
|
description:
|
||||||
|
- This looup returns a list of results from a Redis DB corresponding to a list of items given to it
|
||||||
|
requirements:
|
||||||
|
- redis (python library https://github.com/andymccurdy/redis-py/)
|
||||||
|
options:
|
||||||
|
_terms:
|
||||||
|
description: list of keys to query
|
||||||
|
host:
|
||||||
|
description: location of Redis host
|
||||||
|
default: '127.0.0.1'
|
||||||
|
env:
|
||||||
|
- name: ANSIBLE_REDIS_HOST
|
||||||
|
ini:
|
||||||
|
- section: lookup_redis
|
||||||
|
key: host
|
||||||
|
port:
|
||||||
|
port:
|
||||||
|
description: port on which Redis is listening on
|
||||||
|
default: 6379A
|
||||||
|
type: int
|
||||||
|
env:
|
||||||
|
- name: ANSIBLE_REDIS_PORT
|
||||||
|
ini:
|
||||||
|
- section: lookup_redis
|
||||||
|
key: port
|
||||||
|
socket:
|
||||||
|
description: path to socket on which to query Redis, this option overrides host and port options when set.
|
||||||
|
type: path
|
||||||
|
env:
|
||||||
|
- name: ANSIBLE_REDIS_SOCKET
|
||||||
|
ini:
|
||||||
|
- section: lookup_redis
|
||||||
|
key: socket
|
||||||
|
"""
|
||||||
|
|
||||||
|
EXAMPLES = """
|
||||||
|
- name: query redis for somekey (default or configured settings used)
|
||||||
|
debug: msg="{{ lookup('redis', 'somekey'}}"
|
||||||
|
|
||||||
|
- name: query redis for list of keys and non-default host and port
|
||||||
|
debug: msg="{{ lookup('redis', item, host='myredis.internal.com', port=2121) }}"
|
||||||
|
loop: '{{list_of_redis_keys}}'
|
||||||
|
|
||||||
|
- name: use list directly
|
||||||
|
debug: msg="{{ lookup('redis', 'key1', 'key2', 'key3') }}"
|
||||||
|
|
||||||
|
- name: use list directly with a socket
|
||||||
|
debug: msg="{{ lookup('redis', 'key1', 'key2', socket='/var/tmp/redis.sock') }}"
|
||||||
|
|
||||||
|
"""
|
||||||
|
|
||||||
|
RETURN = """
|
||||||
|
_raw:
|
||||||
|
description: value(s) stored in Redis
|
||||||
|
"""
|
||||||
|
|
||||||
|
import os
|
||||||
|
|
||||||
|
HAVE_REDIS = False
|
||||||
|
try:
|
||||||
|
import redis
|
||||||
|
HAVE_REDIS = True
|
||||||
|
except ImportError:
|
||||||
|
pass
|
||||||
|
|
||||||
|
from ansible.errors import AnsibleError
|
||||||
|
from ansible.plugins.lookup import LookupBase
|
||||||
|
|
||||||
|
|
||||||
|
class LookupModule(LookupBase):
|
||||||
|
|
||||||
|
def run(self, terms, variables, **kwargs):
|
||||||
|
|
||||||
|
if not HAVE_REDIS:
|
||||||
|
raise AnsibleError("Can't LOOKUP(redis_kv): module redis is not installed")
|
||||||
|
|
||||||
|
# get options
|
||||||
|
self.set_options(direct=kwargs)
|
||||||
|
|
||||||
|
# setup connection
|
||||||
|
host = self.get_option('host')
|
||||||
|
port = self.get_option('port')
|
||||||
|
socket = self.get_option('socket')
|
||||||
|
if socket is None:
|
||||||
|
conn = redis.Redis(host=host, port=port)
|
||||||
|
else:
|
||||||
|
conn = redis.Redis(unix_socket_path=socket)
|
||||||
|
|
||||||
|
ret = []
|
||||||
|
for term in terms:
|
||||||
|
try:
|
||||||
|
res = conn.get(term)
|
||||||
|
if res is None:
|
||||||
|
res = ""
|
||||||
|
ret.append(res)
|
||||||
|
except Exception:
|
||||||
|
ret.append("") # connection failed or key not found
|
||||||
|
return ret
|
Loading…
Reference in a new issue