2021-08-07 15:02:21 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
2022-08-05 22:12:10 +02:00
|
|
|
# Copyright (c) 2015, Alejandro Guirao <lekumberri@gmail.com>
|
|
|
|
# Copyright (c) 2012-17 Ansible Project
|
2022-08-05 12:28:29 +02:00
|
|
|
# GNU General Public License v3.0+ (see LICENSES/GPL-3.0-or-later.txt or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
2020-03-09 10:11:07 +01:00
|
|
|
from __future__ import (absolute_import, division, print_function)
|
|
|
|
__metaclass__ = type
|
|
|
|
|
|
|
|
DOCUMENTATION = '''
|
2021-01-12 07:12:03 +01:00
|
|
|
name: shelvefile
|
2020-09-28 21:21:51 +02:00
|
|
|
author: Alejandro Guirao (!UNKNOWN) <lekumberri@gmail.com>
|
2020-03-09 10:11:07 +01:00
|
|
|
short_description: read keys from Python shelve file
|
|
|
|
description:
|
|
|
|
- Read keys from Python shelve file.
|
|
|
|
options:
|
|
|
|
_terms:
|
2022-11-01 21:58:46 +01:00
|
|
|
description: Sets of key value pairs of parameters.
|
2024-07-21 21:03:41 +02:00
|
|
|
type: list
|
|
|
|
elements: str
|
2020-03-09 10:11:07 +01:00
|
|
|
key:
|
2022-11-01 21:58:46 +01:00
|
|
|
description: Key to query.
|
2024-07-21 21:03:41 +02:00
|
|
|
type: str
|
2022-09-06 20:42:17 +02:00
|
|
|
required: true
|
2020-03-09 10:11:07 +01:00
|
|
|
file:
|
2022-11-01 21:58:46 +01:00
|
|
|
description: Path to shelve file.
|
2024-07-21 21:03:41 +02:00
|
|
|
type: path
|
2022-09-06 20:42:17 +02:00
|
|
|
required: true
|
2020-03-09 10:11:07 +01:00
|
|
|
'''
|
|
|
|
|
|
|
|
EXAMPLES = """
|
2022-11-01 21:58:46 +01:00
|
|
|
- name: Retrieve a string value corresponding to a key inside a Python shelve file
|
|
|
|
ansible.builtin.debug:
|
|
|
|
msg: "{{ lookup('community.general.shelvefile', 'file=path_to_some_shelve_file.db key=key_to_retrieve') }}"
|
2020-03-09 10:11:07 +01:00
|
|
|
"""
|
|
|
|
|
|
|
|
RETURN = """
|
|
|
|
_list:
|
2022-11-01 21:58:46 +01:00
|
|
|
description: Value(s) of key(s) in shelve file(s).
|
2020-09-16 11:06:45 +02:00
|
|
|
type: list
|
|
|
|
elements: str
|
2020-03-09 10:11:07 +01:00
|
|
|
"""
|
|
|
|
import shelve
|
|
|
|
|
|
|
|
from ansible.errors import AnsibleError, AnsibleAssertionError
|
|
|
|
from ansible.plugins.lookup import LookupBase
|
2021-06-26 23:59:11 +02:00
|
|
|
from ansible.module_utils.common.text.converters import to_bytes, to_text
|
2020-03-09 10:11:07 +01:00
|
|
|
|
|
|
|
|
|
|
|
class LookupModule(LookupBase):
|
|
|
|
|
|
|
|
def read_shelve(self, shelve_filename, key):
|
|
|
|
"""
|
|
|
|
Read the value of "key" from a shelve file
|
|
|
|
"""
|
|
|
|
d = shelve.open(to_bytes(shelve_filename))
|
|
|
|
res = d.get(key, None)
|
|
|
|
d.close()
|
|
|
|
return res
|
|
|
|
|
|
|
|
def run(self, terms, variables=None, **kwargs):
|
|
|
|
if not isinstance(terms, list):
|
|
|
|
terms = [terms]
|
|
|
|
|
|
|
|
ret = []
|
|
|
|
|
|
|
|
for term in terms:
|
|
|
|
paramvals = {"file": None, "key": None}
|
|
|
|
params = term.split()
|
|
|
|
|
|
|
|
try:
|
|
|
|
for param in params:
|
|
|
|
name, value = param.split('=')
|
|
|
|
if name not in paramvals:
|
|
|
|
raise AnsibleAssertionError('%s not in paramvals' % name)
|
|
|
|
paramvals[name] = value
|
|
|
|
|
|
|
|
except (ValueError, AssertionError) as e:
|
|
|
|
# In case "file" or "key" are not present
|
|
|
|
raise AnsibleError(e)
|
|
|
|
|
|
|
|
key = paramvals['key']
|
|
|
|
|
|
|
|
# Search also in the role/files directory and in the playbook directory
|
|
|
|
shelvefile = self.find_file_in_search_path(variables, 'files', paramvals['file'])
|
|
|
|
|
|
|
|
if shelvefile:
|
|
|
|
res = self.read_shelve(shelvefile, key)
|
|
|
|
if res is None:
|
|
|
|
raise AnsibleError("Key %s not found in shelve file %s" % (key, shelvefile))
|
|
|
|
# Convert the value read to string
|
|
|
|
ret.append(to_text(res))
|
|
|
|
break
|
|
|
|
else:
|
|
|
|
raise AnsibleError("Could not locate shelve file in lookup: %s" % paramvals['file'])
|
|
|
|
|
|
|
|
return ret
|