From 01ca9b1d0ec882f5eea7fc42ef7f7dab9ea76d19 Mon Sep 17 00:00:00 2001 From: Abhijeet Kasurde Date: Tue, 10 Dec 2024 08:08:24 -0800 Subject: uri: move follow_redirects to module_utils (#84442) * url lookup and uri module shares follow_redirects parameter, moving it module_utils code. Signed-off-by: Abhijeet Kasurde --- changelogs/fragments/follow_redirects_url.yml | 3 +++ lib/ansible/module_utils/urls.py | 10 ++++++++++ lib/ansible/modules/uri.py | 23 ++++++++++------------- lib/ansible/plugins/doc_fragments/url.py | 16 ++++++++++++++++ lib/ansible/plugins/lookup/url.py | 10 ++-------- 5 files changed, 41 insertions(+), 21 deletions(-) create mode 100644 changelogs/fragments/follow_redirects_url.yml diff --git a/changelogs/fragments/follow_redirects_url.yml b/changelogs/fragments/follow_redirects_url.yml new file mode 100644 index 0000000000..53e9bfd97a --- /dev/null +++ b/changelogs/fragments/follow_redirects_url.yml @@ -0,0 +1,3 @@ +--- +minor_changes: + - Move ``follow_redirects`` parameter to module_utils so external modules can reuse it. diff --git a/lib/ansible/module_utils/urls.py b/lib/ansible/module_utils/urls.py index 282210b27a..09ea835d72 100644 --- a/lib/ansible/module_utils/urls.py +++ b/lib/ansible/module_utils/urls.py @@ -1153,6 +1153,16 @@ def url_argument_spec(): ) +def url_redirect_argument_spec(): + """ + Creates an addition arugment spec to `url_argument_spec` + for `follow_redirects` argument + """ + return dict( + follow_redirects=dict(type='str', default='safe', choices=['all', 'no', 'none', 'safe', 'urllib2', 'yes']), + ) + + def fetch_url(module, url, data=None, headers=None, method=None, use_proxy=None, force=False, last_mod_time=None, timeout=10, use_gssapi=False, unix_socket=None, ca_path=None, cookies=None, unredirected_headers=None, diff --git a/lib/ansible/modules/uri.py b/lib/ansible/modules/uri.py index b193d0ac06..3229c746c7 100644 --- a/lib/ansible/modules/uri.py +++ b/lib/ansible/modules/uri.py @@ -106,18 +106,6 @@ options: - The webservice bans or rate-limits clients that cause any HTTP 401 errors. type: bool default: no - follow_redirects: - description: - - Whether or not the URI module should follow redirects. - type: str - default: safe - choices: - all: Will follow all redirects. - none: Will not follow any redirects. - safe: Only redirects doing GET or HEAD requests will be followed. - urllib2: Defer to urllib2 behavior (As of writing this follows HTTP redirects). - 'no': (DEPRECATED, removed in 2.22) alias of V(none). - 'yes': (DEPRECATED, removed in 2.22) alias of V(all). creates: description: - A filename, when it already exists, this step will not be run. @@ -235,6 +223,7 @@ options: extends_documentation_fragment: - action_common_attributes - files + - url.url_redirect attributes: check_mode: support: none @@ -455,7 +444,14 @@ from ansible.module_utils.six.moves.urllib.parse import urlencode, urlsplit from ansible.module_utils.common.text.converters import to_native, to_text from ansible.module_utils.compat.datetime import utcnow, utcfromtimestamp from ansible.module_utils.six.moves.collections_abc import Mapping, Sequence -from ansible.module_utils.urls import fetch_url, get_response_filename, parse_content_type, prepare_multipart, url_argument_spec +from ansible.module_utils.urls import ( + fetch_url, + get_response_filename, + parse_content_type, + prepare_multipart, + url_argument_spec, + url_redirect_argument_spec, +) JSON_CANDIDATES = {'json', 'javascript'} @@ -609,6 +605,7 @@ def uri(module, url, dest, body, body_format, method, headers, socket_timeout, c def main(): argument_spec = url_argument_spec() argument_spec['url']['required'] = True + argument_spec.update(url_redirect_argument_spec()) argument_spec.update( dest=dict(type='path'), url_username=dict(type='str', aliases=['user']), diff --git a/lib/ansible/plugins/doc_fragments/url.py b/lib/ansible/plugins/doc_fragments/url.py index bddc33db98..942558f166 100644 --- a/lib/ansible/plugins/doc_fragments/url.py +++ b/lib/ansible/plugins/doc_fragments/url.py @@ -72,3 +72,19 @@ options: default: no version_added: '2.11' """ + + URL_REDIRECT = r''' +options: + follow_redirects: + description: + - Whether or not the URI module should follow redirects. + type: str + default: safe + choices: + all: Will follow all redirects. + none: Will not follow any redirects. + safe: Only redirects doing GET or HEAD requests will be followed. + urllib2: Defer to urllib2 behavior (As of writing this follows HTTP redirects). + 'no': (DEPRECATED, removed in 2.22) alias of V(none). + 'yes': (DEPRECATED, removed in 2.22) alias of V(all). +''' diff --git a/lib/ansible/plugins/lookup/url.py b/lib/ansible/plugins/lookup/url.py index 4775ecfb0c..7c15cba3e0 100644 --- a/lib/ansible/plugins/lookup/url.py +++ b/lib/ansible/plugins/lookup/url.py @@ -87,7 +87,6 @@ options: - section: url_lookup key: force_basic_auth follow_redirects: - description: String of urllib2, all/yes, safe, none to determine how redirects are followed type: string version_added: "2.10" default: 'urllib2' @@ -98,13 +97,6 @@ options: ini: - section: url_lookup key: follow_redirects - choices: - all: Will follow all redirects. - none: Will not follow any redirects. - safe: Only redirects doing GET or HEAD requests will be followed. - urllib2: Defer to urllib2 behavior (As of writing this follows HTTP redirects). - 'no': (DEPRECATED, removed in 2.22) alias of V(none). - 'yes': (DEPRECATED, removed in 2.22) alias of V(all). use_gssapi: description: - Use GSSAPI handler of requests @@ -185,6 +177,8 @@ options: ini: - section: url_lookup key: ciphers +extends_documentation_fragment: + - url.url_redirect """ EXAMPLES = """ -- cgit v1.2.3