mirror of
				https://github.com/ansible-collections/community.general.git
				synced 2025-10-25 13:34:01 -07:00 
			
		
		
		
	* Fix deprecation of callables. * Fix various sanity errors. * Revert callback_type -> type transform. * Fix stat_result times: these are float according to https://github.com/python/typeshed/blob/master/stdlib/3/os/__init__.pyi * Apply suggestions from code review Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru> Co-authored-by: Andrew Klychkov <aaklychkov@mail.ru>
		
			
				
	
	
		
			120 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			120 lines
		
	
	
	
		
			3.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # (c) 2017-2018, Jan-Piet Mens <jpmens(at)gmail.com>
 | |
| # (c) 2018 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: lmdb_kv
 | |
|     author:
 | |
|       - Jan-Piet Mens (@jpmens)
 | |
|     version_added: '0.2.0'
 | |
|     short_description: fetch data from LMDB
 | |
|     description:
 | |
|       - This lookup returns a list of results from an LMDB DB corresponding to a list of items given to it
 | |
|     requirements:
 | |
|       - lmdb (python library https://lmdb.readthedocs.io/en/release/)
 | |
|     options:
 | |
|       _terms:
 | |
|         description: list of keys to query
 | |
|       db:
 | |
|         description: path to LMDB database
 | |
|         default: 'ansible.mdb'
 | |
| '''
 | |
| 
 | |
| EXAMPLES = """
 | |
| - name: query LMDB for a list of country codes
 | |
|   ansible.builtin.debug:
 | |
|     msg: "{{ query('community.general.lmdb_kv', 'nl', 'be', 'lu', db='jp.mdb') }}"
 | |
| 
 | |
| - name: use list of values in a loop by key wildcard
 | |
|   ansible.builtin.debug:
 | |
|     msg: "Hello from {{ item.0 }} a.k.a. {{ item.1 }}"
 | |
|   vars:
 | |
|     - lmdb_kv_db: jp.mdb
 | |
|   with_community.general.lmdb_kv:
 | |
|      - "n*"
 | |
| 
 | |
| - name: get an item by key
 | |
|   ansible.builtin.assert:
 | |
|     that:
 | |
|       - item == 'Belgium'
 | |
|     vars:
 | |
|       - lmdb_kv_db: jp.mdb
 | |
|     with_community.general.lmdb_kv:
 | |
|       - be
 | |
| """
 | |
| 
 | |
| RETURN = """
 | |
| _raw:
 | |
|   description: value(s) stored in LMDB
 | |
|   type: list
 | |
|   elements: raw
 | |
| """
 | |
| 
 | |
| 
 | |
| from ansible.errors import AnsibleError
 | |
| from ansible.plugins.lookup import LookupBase
 | |
| from ansible.module_utils._text import to_native, to_text
 | |
| HAVE_LMDB = True
 | |
| try:
 | |
|     import lmdb
 | |
| except ImportError:
 | |
|     HAVE_LMDB = False
 | |
| 
 | |
| 
 | |
| class LookupModule(LookupBase):
 | |
| 
 | |
|     def run(self, terms, variables, **kwargs):
 | |
| 
 | |
|         '''
 | |
|         terms contain any number of keys to be retrieved.
 | |
|         If terms is None, all keys from the database are returned
 | |
|         with their values, and if term ends in an asterisk, we
 | |
|         start searching there
 | |
| 
 | |
|         The LMDB database defaults to 'ansible.mdb' if Ansible's
 | |
|         variable 'lmdb_kv_db' is not set:
 | |
| 
 | |
|               vars:
 | |
|                 - lmdb_kv_db: "jp.mdb"
 | |
|         '''
 | |
| 
 | |
|         if HAVE_LMDB is False:
 | |
|             raise AnsibleError("Can't LOOKUP(lmdb_kv): this module requires lmdb to be installed")
 | |
| 
 | |
|         db = variables.get('lmdb_kv_db', None)
 | |
|         if db is None:
 | |
|             db = kwargs.get('db', 'ansible.mdb')
 | |
|         db = str(db)
 | |
| 
 | |
|         try:
 | |
|             env = lmdb.open(db, readonly=True)
 | |
|         except Exception as e:
 | |
|             raise AnsibleError("LMDB can't open database %s: %s" % (db, to_native(e)))
 | |
| 
 | |
|         ret = []
 | |
|         if len(terms) == 0:
 | |
|             with env.begin() as txn:
 | |
|                 cursor = txn.cursor()
 | |
|                 cursor.first()
 | |
|                 for key, value in cursor:
 | |
|                     ret.append((to_text(key), to_native(value)))
 | |
| 
 | |
|         else:
 | |
|             for term in terms:
 | |
|                 with env.begin() as txn:
 | |
|                     if term.endswith('*'):
 | |
|                         cursor = txn.cursor()
 | |
|                         prefix = term[:-1]  # strip asterisk
 | |
|                         cursor.set_range(to_text(term).encode())
 | |
|                         while cursor.key().startswith(to_text(prefix).encode()):
 | |
|                             for key, value in cursor:
 | |
|                                 ret.append((to_text(key), to_native(value)))
 | |
|                             cursor.next()
 | |
|                     else:
 | |
|                         value = txn.get(to_text(term).encode())
 | |
|                         if value is not None:
 | |
|                             ret.append(to_native(value))
 | |
| 
 | |
|         return ret
 |