You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
145 lines
4.5 KiB
145 lines
4.5 KiB
14 years ago
|
# -*- coding: utf-8 -*-
|
||
|
|
||
|
"""
|
||
|
requests.api
|
||
|
~~~~~~~~~~~~
|
||
|
|
||
|
This module implements the Requests API.
|
||
|
|
||
|
:copyright: (c) 2011 by Kenneth Reitz.
|
||
|
:license: ISC, see LICENSE for more details.
|
||
|
|
||
|
"""
|
||
|
|
||
|
from . import sessions
|
||
|
|
||
|
def request(method, url,
|
||
|
params=None,
|
||
|
data=None,
|
||
|
headers=None,
|
||
|
cookies=None,
|
||
|
files=None,
|
||
|
auth=None,
|
||
|
timeout=None,
|
||
|
allow_redirects=False,
|
||
|
proxies=None,
|
||
|
hooks=None,
|
||
|
return_response=True,
|
||
|
prefetch=False,
|
||
|
session=None,
|
||
|
config=None):
|
||
|
"""Constructs and sends a :class:`Request <Request>`.
|
||
|
Returns :class:`Response <Response>` object.
|
||
|
|
||
|
:param method: method for the new :class:`Request` object.
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param params: (optional) Dictionary or bytes to be sent in the query string for the :class:`Request`.
|
||
|
:param data: (optional) Dictionary or bytes to send in the body of the :class:`Request`.
|
||
|
:param headers: (optional) Dictionary of HTTP Headers to send with the :class:`Request`.
|
||
|
:param cookies: (optional) Dict or CookieJar object to send with the :class:`Request`.
|
||
|
:param files: (optional) Dictionary of 'name': file-like-objects (or {'name': ('filename', fileobj)}) for multipart encoding upload.
|
||
|
:param auth: (optional) Auth tuple to enable Basic/Digest/Custom HTTP Auth.
|
||
|
:param timeout: (optional) Float describing the timeout of the request.
|
||
|
:param allow_redirects: (optional) Boolean. Set to True if POST/PUT/DELETE redirect following is allowed.
|
||
|
:param proxies: (optional) Dictionary mapping protocol to the URL of the proxy.
|
||
|
:param return_response: (optional) If False, an un-sent Request object will returned.
|
||
|
:param session: (optional) A :class:`Session` object to be used for the request.
|
||
|
:param config: (optional) A configuration dictionary.
|
||
|
"""
|
||
|
|
||
|
s = session or sessions.session()
|
||
|
return s.request(
|
||
|
method=method,
|
||
|
url=url,
|
||
|
params=params,
|
||
|
data=data,
|
||
|
headers=headers,
|
||
|
cookies=cookies,
|
||
|
files=files,
|
||
|
auth=auth,
|
||
|
timeout=timeout,
|
||
|
allow_redirects=allow_redirects,
|
||
|
proxies=proxies,
|
||
|
hooks=hooks,
|
||
|
return_response=return_response,
|
||
|
config=config,
|
||
|
prefetch=prefetch
|
||
|
)
|
||
|
|
||
|
|
||
|
|
||
|
def get(url, **kwargs):
|
||
|
"""Sends a GET request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
kwargs.setdefault('allow_redirects', True)
|
||
|
return request('get', url, **kwargs)
|
||
|
|
||
|
|
||
|
def options(url, **kwargs):
|
||
|
"""Sends a OPTIONS request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
kwargs.setdefault('allow_redirects', True)
|
||
|
return request('options', url, **kwargs)
|
||
|
|
||
|
|
||
|
def head(url, **kwargs):
|
||
|
"""Sends a HEAD request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
kwargs.setdefault('allow_redirects', True)
|
||
|
return request('head', url, **kwargs)
|
||
|
|
||
|
|
||
|
def post(url, data=None, **kwargs):
|
||
|
"""Sends a POST request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param data: (optional) Dictionary or bytes to send in the body of the :class:`Request`.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
return request('post', url, data=data, **kwargs)
|
||
|
|
||
|
|
||
|
def put(url, data=None, **kwargs):
|
||
|
"""Sends a PUT request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param data: (optional) Dictionary or bytes to send in the body of the :class:`Request`.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
return request('put', url, data=data, **kwargs)
|
||
|
|
||
|
|
||
|
def patch(url, data=None, **kwargs):
|
||
|
"""Sends a PATCH request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param data: (optional) Dictionary or bytes to send in the body of the :class:`Request`.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
return request('patch', url, data=data, **kwargs)
|
||
|
|
||
|
|
||
|
def delete(url, **kwargs):
|
||
|
"""Sends a DELETE request. Returns :class:`Response` object.
|
||
|
|
||
|
:param url: URL for the new :class:`Request` object.
|
||
|
:param **kwargs: Optional arguments that ``request`` takes.
|
||
|
"""
|
||
|
|
||
|
return request('delete', url, **kwargs)
|