mirror of
https://github.com/ansible-collections/community.general.git
synced 2024-09-14 20:13:21 +02:00
a0178b79f1
* win_uri: moved away from Invoke-WebRequest and fixed multiple issues * fixes from review
211 lines
7.1 KiB
Python
211 lines
7.1 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
|
|
# Copyright: (c) 2015, Corwin Brown <corwin@corwinbrown.com>
|
|
# Copyright: (c) 2017, Dag Wieers (@dagwieers) <dag@wieers.com>
|
|
# GNU General Public License v3.0+ (see COPYING or https://www.gnu.org/licenses/gpl-3.0.txt)
|
|
|
|
ANSIBLE_METADATA = {'metadata_version': '1.1',
|
|
'status': ['preview'],
|
|
'supported_by': 'community'}
|
|
|
|
DOCUMENTATION = r'''
|
|
---
|
|
module: win_uri
|
|
version_added: '2.1'
|
|
short_description: Interacts with webservices
|
|
description:
|
|
- Interacts with FTP, HTTP and HTTPS web services.
|
|
- Supports Digest, Basic and WSSE HTTP authentication mechanisms.
|
|
- For non-Windows targets, use the M(uri) module instead.
|
|
options:
|
|
url:
|
|
description:
|
|
- Supports FTP, HTTP or HTTPS URLs in the form of (ftp|http|https)://host.domain:port/path.
|
|
required: yes
|
|
method:
|
|
description:
|
|
- The HTTP Method of the request or response.
|
|
choices: [ CONNECT, DELETE, GET, HEAD, MERGE, OPTIONS, PATCH, POST, PUT, REFRESH, TRACE ]
|
|
default: GET
|
|
content_type:
|
|
description:
|
|
- Sets the "Content-Type" header.
|
|
body:
|
|
description:
|
|
- The body of the HTTP request/response to the web service.
|
|
user:
|
|
description:
|
|
- Username to use for authentication.
|
|
version_added: '2.4'
|
|
password:
|
|
description:
|
|
- Password to use for authentication.
|
|
version_added: '2.4'
|
|
force_basic_auth:
|
|
description:
|
|
- By default the authentication information is only sent when a webservice
|
|
responds to an initial request with a 401 status. Since some basic auth
|
|
services do not properly send a 401, logins will fail.
|
|
- This option forces the sending of the Basic authentication header upon
|
|
the initial request.
|
|
type: bool
|
|
default: 'no'
|
|
version_added: '2.5'
|
|
dest:
|
|
description:
|
|
- Output the response body to a file.
|
|
version_added: '2.3'
|
|
headers:
|
|
description:
|
|
- Extra headers to set on the request, see the examples for more details on
|
|
how to set this.
|
|
use_basic_parsing:
|
|
description:
|
|
- As of Ansible 2.5, this option is no longer valid and cannot be changed from C(yes), this option will be removed
|
|
in Ansible 2.7.
|
|
- Before Ansible 2.5, this module relies upon 'Invoke-WebRequest', which by default uses the Internet Explorer Engine
|
|
to parse a webpage.
|
|
- There's an edge-case where if a user hasn't run IE before, this will fail.
|
|
- The only advantage to using the Internet Explorer praser is that you can traverse the DOM in a powershell script.
|
|
- That isn't useful for Ansible, so by default we toggle 'UseBasicParsing'. However, you can toggle that off here.
|
|
type: bool
|
|
default: 'yes'
|
|
creates:
|
|
description:
|
|
- A filename, when it already exists, this step will be skipped.
|
|
version_added: '2.4'
|
|
removes:
|
|
description:
|
|
- A filename, when it does not exist, this step will be skipped.
|
|
version_added: '2.4'
|
|
return_content:
|
|
description:
|
|
- Whether or not to return the body of the response as a "content" key in
|
|
the dictionary result. If the reported Content-type is
|
|
"application/json", then the JSON is additionally loaded into a key
|
|
called C(json) in the dictionary results.
|
|
type: bool
|
|
default: 'no'
|
|
version_added: '2.4'
|
|
status_code:
|
|
description:
|
|
- A valid, numeric, HTTP status code that signifies success of the request.
|
|
- Can also be comma separated list of status codes.
|
|
default: 200
|
|
version_added: '2.4'
|
|
timeout:
|
|
description:
|
|
- Specifies how long the request can be pending before it times out (in seconds).
|
|
- The value 0 (zero) specifies an indefinite time-out.
|
|
- A Domain Name System (DNS) query can take up to 15 seconds to return or time out.
|
|
If your request contains a host name that requires resolution, and you set
|
|
C(timeout) to a value greater than zero, but less than 15 seconds, it can
|
|
take 15 seconds or more before your request times out.
|
|
default: 30
|
|
version_added: '2.4'
|
|
follow_redirects:
|
|
description:
|
|
- Whether or not the C(win_uri) module should follow redirects.
|
|
- C(all) will follow all redirects.
|
|
- C(none) will not follow any redirects.
|
|
- C(safe) will follow only "safe" redirects, where "safe" means that the client is only
|
|
doing a C(GET) or C(HEAD) on the URI to which it is being redirected.
|
|
choices: [ all, none, safe ]
|
|
default: safe
|
|
version_added: '2.4'
|
|
maximum_redirection:
|
|
description:
|
|
- Specifies how many times C(win_uri) redirects a connection to an alternate
|
|
Uniform Resource Identifier (URI) before the connection fails.
|
|
- If C(maximum_redirection) is set to 0 (zero)
|
|
or C(follow_redirects) is set to C(none),
|
|
or set to C(safe) when not doing C(GET) or C(HEAD) it prevents all redirection.
|
|
default: 5
|
|
version_added: '2.4'
|
|
validate_certs:
|
|
description:
|
|
- If C(no), SSL certificates will not be validated. This should only
|
|
set to C(no) used on personally controlled sites using self-signed
|
|
certificates.
|
|
type: bool
|
|
default: 'yes'
|
|
version_added: '2.4'
|
|
client_cert:
|
|
description:
|
|
- Specifies the client certificate (.pfx) that is used for a secure web request.
|
|
- The WinRM connection must be authenticated with C(CredSSP) if the
|
|
certificate file is not password protected.
|
|
- Other authentication types can set I(client_cert_password) when the cert
|
|
is password protected.
|
|
version_added: '2.4'
|
|
client_cert_password:
|
|
description:
|
|
- The password for the client certificate (.pfx) file that is used for a
|
|
secure web request.
|
|
version_added: '2.5'
|
|
notes:
|
|
- For non-Windows targets, use the M(uri) module instead.
|
|
author:
|
|
- Corwin Brown (@blakfeld)
|
|
- Dag Wieers (@dagwieers)
|
|
'''
|
|
|
|
EXAMPLES = r'''
|
|
- name: Perform a GET and Store Output
|
|
win_uri:
|
|
url: http://example.com/endpoint
|
|
register: http_output
|
|
|
|
# Set a HOST header to hit an internal webserver:
|
|
- name: Hit a Specific Host on the Server
|
|
win_uri:
|
|
url: http://example.com/
|
|
method: GET
|
|
headers:
|
|
host: www.somesite.com
|
|
|
|
- name: Perform a HEAD on an Endpoint
|
|
win_uri:
|
|
url: http://www.example.com/
|
|
method: HEAD
|
|
|
|
- name: POST a Body to an Endpoint
|
|
win_uri:
|
|
url: http://www.somesite.com/
|
|
method: POST
|
|
body: "{ 'some': 'json' }"
|
|
'''
|
|
|
|
RETURN = r'''
|
|
url:
|
|
description: The Target URL
|
|
returned: always
|
|
type: string
|
|
sample: https://www.ansible.com
|
|
status_code:
|
|
description: The HTTP Status Code of the response.
|
|
returned: success
|
|
type: int
|
|
sample: 200
|
|
status_description:
|
|
description: A summery of the status.
|
|
returned: success
|
|
type: string
|
|
sample: OK
|
|
content:
|
|
description: The raw content of the HTTP response.
|
|
returned: success and return_content is True
|
|
type: string
|
|
sample: '{"foo": "bar"}'
|
|
content_length:
|
|
description: The byte size of the response.
|
|
returned: success
|
|
type: int
|
|
sample: 54447
|
|
json:
|
|
description: The json structure returned under content as a dictionary
|
|
returned: success and Content-Type is "application/json" or "application/javascript" and return_content is True
|
|
type: dict
|
|
sample: {"this-is-dependent": "on the actual return content"}
|
|
'''
|