mirror of
https://github.com/ansible-collections/community.general.git
synced 2026-06-05 15:57:05 +00:00
Lookup plugins: prevent using _terms for positional arguments, and reject positional arguments completely for lookups that don't use them (#12060)
Prevent using _terms for positional arguments. Also rejecting positional arguments completely for lookups that don't use them.
This commit is contained in:
parent
f97ff78c20
commit
2d8e6cb851
37 changed files with 151 additions and 1 deletions
38
plugins/plugin_utils/_lookup.py
Normal file
38
plugins/plugin_utils/_lookup.py
Normal file
|
|
@ -0,0 +1,38 @@
|
|||
# Copyright (c) 2026 Felix Fontein <felix@fontein.de>
|
||||
# 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
|
||||
|
||||
# Note that this plugin util is **PRIVATE** to the collection. It can have breaking changes at any time.
|
||||
# Do not use this from other collections or standalone plugins/modules!
|
||||
|
||||
from __future__ import annotations
|
||||
|
||||
import typing as t
|
||||
|
||||
from ansible.errors import AnsibleLookupError
|
||||
|
||||
if t.TYPE_CHECKING:
|
||||
from collections.abc import Mapping, Sequence
|
||||
|
||||
from ansible.plugins.lookup import LookupBase
|
||||
|
||||
|
||||
def check_for_wrong_terms(plugin: LookupBase, *, direct: Mapping[str, t.Any]) -> None:
|
||||
# Note that we don't check "terms" here since the keyword argument "terms"
|
||||
# is mapped by Python to the run() positional argument "terms".
|
||||
for opt in ("_terms",):
|
||||
if opt in direct:
|
||||
raise AnsibleLookupError(
|
||||
f"The {opt!r} keyword argument is not supported, you must provide terms as positional arguments: use"
|
||||
f" lookup({plugin.ansible_name!r}, arg1, arg2) instead of lookup({plugin.ansible_name!r}, {opt}=[arg1, arg2])"
|
||||
)
|
||||
|
||||
|
||||
def check_for_no_terms(plugin: LookupBase, *, terms: Sequence[t.Any], direct: Mapping[str, t.Any]) -> None:
|
||||
if terms:
|
||||
raise AnsibleLookupError("The lookup plugin does not accept positional arguments")
|
||||
# Note that we don't check "terms" here since the keyword argument "terms"
|
||||
# is mapped by Python to the run() positional argument "terms".
|
||||
for opt in ("_terms",):
|
||||
if opt in direct:
|
||||
raise AnsibleLookupError(f"The {opt!r} keyword argument is not supported")
|
||||
Loading…
Add table
Add a link
Reference in a new issue