ó
sÒARc           @   sk   d  Z  d d l m Z d „  Z d „  Z d „  Z d „  Z d d „ Z d d „ Z	 d d	 „ Z
 d
 „  Z d S(   sŸ   
requests.api
~~~~~~~~~~~~

This module implements the Requests API.

:copyright: (c) 2012 by Kenneth Reitz.
:license: Apache2, see LICENSE for more details.

i   (   t   sessionsc         K   s%   t  j ƒ  } | j d |  d | |  S(   s  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, bytes, or file-like object 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 verify: (optional) if ``True``, the SSL cert will be verified. A CA_BUNDLE path can also be provided.
    :param stream: (optional) if ``False``, the response content will be immediately downloaded.
    :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair.

    Usage::

      >>> import requests
      >>> req = requests.request('GET', 'http://httpbin.org/get')
      <Response [200]>
    t   methodt   url(   R    t   Sessiont   request(   R   R   t   kwargst   session(    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR      s    c         K   s    | j  d t ƒ t d |  |  S(   s·   Sends a GET request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    t   allow_redirectst   get(   t
   setdefaultt   TrueR   (   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   /   s    c         K   s    | j  d t ƒ t d |  |  S(   s»   Sends a OPTIONS request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    R   t   options(   R	   R
   R   (   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   :   s    c         K   s    | j  d t ƒ t d |  |  S(   s¸   Sends a HEAD request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    R   t   head(   R	   t   FalseR   (   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   E   s    c         K   s   t  d |  d | | S(   s(  Sends a POST request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param data: (optional) Dictionary, bytes, or file-like object to send in the body of the :class:`Request`.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    t   postt   data(   R   (   R   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   P   s    c         K   s   t  d |  d | | S(   s'  Sends a PUT request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param data: (optional) Dictionary, bytes, or file-like object to send in the body of the :class:`Request`.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    t   putR   (   R   (   R   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   [   s    c         K   s   t  d |  d | | S(   s)  Sends a PATCH request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param data: (optional) Dictionary, bytes, or file-like object to send in the body of the :class:`Request`.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    t   patchR   (   R   (   R   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   f   s    c         K   s   t  d |  |  S(   sº   Sends a DELETE request. Returns :class:`Response` object.

    :param url: URL for the new :class:`Request` object.
    :param \*\*kwargs: Optional arguments that ``request`` takes.
    t   delete(   R   (   R   R   (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyR   q   s    N(   t   __doc__t    R    R   R   R   R   t   NoneR   R   R   R   (    (    (    s0   /usr/lib/python2.7/dist-packages/requests/api.pyt   <module>   s   				