ó
¨9Vc           @   sÅ  d  Z  d d l Z d d l m Z d d l m Z d d l m Z d d l m Z m	 Z	 m
 Z
 m Z d d l m Z m Z m Z m Z d d	 l m Z m Z m Z d d
 l m Z m Z d d l m Z m Z m Z d d l m Z m Z m Z m  Z  d d l! m" Z" d d l# m$ Z$ d d l% m& Z& d d l m' Z' m( Z( m) Z) m* Z* m+ Z+ d d l, m- Z- d d l m. Z. d Z/ e	 d „ Z0 e	 d „ Z1 d e2 f d „  ƒ  YZ3 d e3 f d „  ƒ  YZ4 d „  Z5 d S(   s”   
requests.session
~~~~~~~~~~~~~~~~

This module provides a Session object to manage and persist settings across
requests (cookies, auth, proxies).

iÿÿÿÿN(   t   Mapping(   t   datetimei   (   t   _basic_auth_str(   t	   cookielibt   OrderedDictt   urljoint   urlparse(   t   cookiejar_from_dictt   extract_cookies_to_jart   RequestsCookieJart   merge_cookies(   t   Requestt   PreparedRequestt   DEFAULT_REDIRECT_LIMIT(   t   default_hookst   dispatch_hook(   t   to_key_val_listt   default_headerst   to_native_string(   t   TooManyRedirectst   InvalidSchemat   ChunkedEncodingErrort   ContentDecodingError(   t   RecentlyUsedContainer(   t   CaseInsensitiveDict(   t   HTTPAdapter(   t   requote_urit   get_environ_proxiest   get_netrc_autht   should_bypass_proxiest   get_auth_from_url(   t   codes(   t   REDIRECT_STATIiè  c         C   sº   | d k r |  S|  d k r  | St | t ƒ o; t |  t ƒ sB |  S| t | ƒ ƒ } | j t |  ƒ ƒ x0 |  j ƒ  D]" \ } } | d k rt | | =qt qt Wt d „  | j ƒ  Dƒ ƒ } | S(   sí   
    Determines appropriate setting for a given request, taking into account the
    explicit setting on that request, and the setting in the session. If a
    setting is a dictionary, they will be merged together using `dict_class`
    c         s   s-   |  ]# \ } } | d  k	 r | | f Vq d  S(   N(   t   None(   t   .0t   kt   v(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pys	   <genexpr>F   s    N(   R!   t
   isinstanceR    R   t   updatet   itemst   dict(   t   request_settingt   session_settingt
   dict_classt   merged_settingR#   R$   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   merge_setting*   s    c         C   sZ   | d k s! | j d ƒ g  k r% |  S|  d k sF |  j d ƒ g  k rJ | St |  | | ƒ S(   s®   
    Properly merges both requests and session hooks.

    This is necessary because when request_hooks == {'response': []}, the
    merge breaks Session hooks entirely.
    t   responseN(   R!   t   getR-   (   t   request_hookst   session_hooksR+   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   merge_hooksK   s
    !!t   SessionRedirectMixinc           B   s2   e  Z e d e d d d  „ Z d „  Z d „  Z RS(   c         k   s>  d }	 g  }
 x+| j  r9| j ƒ  } |	 d k rU |
 j | ƒ t |
 ƒ } | | _ n  y | j Wn- t t t f k
 r | j	 j
 d t ƒ n X|	 |  j k rµ t d |  j ƒ ‚ n  | j ƒ  | j d } | j } | j d ƒ r	t | j ƒ } d | j | f } n  t | ƒ } | j ƒ  } | j sEt | j t | ƒ ƒ } n t | ƒ } t | ƒ | _ | j r‘| j | j k r‘| j |  j | j <n  | j t j k r¸| d k r¸d } n  | j t j k rß| d k rßd } n  | j t j  k r| d	 k rd } n  | | _ | j t j! t j" f k rRd
 | j k rF| j d
 =n  d | _$ n  | j } y | d =Wn t% k
 ryn Xt& | j' | | j	 ƒ | j' j( |  j) ƒ | j* | j' ƒ |  j+ | | ƒ } |  j, | | ƒ | } |  j- | d | d | d | d | d | d t | } t& |  j) | | j	 ƒ |	 d 7}	 | Vq Wd S(   s6   Receives a Response. Returns a generator of Responses.i    t   decode_contents   Exceeded %s redirects.t   locations   //s   %s:%st   HEADt   GETt   POSTs   Content-Lengtht   Cookiet   streamt   timeoutt   verifyt   certt   proxiest   allow_redirectsi   N(.   t   is_redirectt   copyt   appendt   listt   historyt   contentR   R   t   RuntimeErrort   rawt   readt   Falset   max_redirectsR   t   closet   headerst   methodt
   startswithR   t   urlt   schemet   geturlt   netlocR   R   R   t   is_permanent_redirectt   redirect_cachet   status_codeR   t	   see_othert   foundt   movedt   temporary_redirectt   permanent_redirectR!   t   bodyt   KeyErrorR   t   _cookiesR&   t   cookiest   prepare_cookiest   rebuild_proxiest   rebuild_autht   send(   t   selft   respt   reqR:   R;   R<   R=   R>   t   adapter_kwargst   it   histt   prepared_requestt   new_histRO   RM   t   parsed_rurlt   parsedRL   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   resolve_redirects\   s~    
								
c         C   s–   | j  } | j } d | k r[ t | j j ƒ } t | ƒ } | j | j k r[ | d =q[ n  |  j rp t | ƒ n d } | d k	 r’ | j | ƒ n  d S(   sò   
        When being redirected we may want to strip authentication from the
        request to avoid leaking credentials. This method intelligently removes
        and reapplies authentication where possible to avoid credential loss.
        t   AuthorizationN(	   RL   RO   R   t   requestt   hostnamet	   trust_envR   R!   t   prepare_auth(   Rc   Ri   R.   RL   RO   t   original_parsedt   redirect_parsedt   new_auth(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyRa   Ì   s    		c         C   s  | j  } | j } t | ƒ j } | d k	 r9 | j ƒ  n i  } |  j r t | ƒ r t | ƒ } | j	 | ƒ } | r | j
 | | | ƒ q n  d | k r¦ | d =n  y t | | ƒ \ }	 }
 Wn t k
 rß d \ }	 }
 n X|	 r|
 rt |	 |
 ƒ | d <n  | S(   s£  
        This method re-evaluates the proxy configuration by considering the
        environment variables. If we are redirected to a URL covered by
        NO_PROXY, we strip the proxy configuration. Otherwise, we set missing
        proxy keys for this URL (in case they were stripped by a previous
        redirect).

        This method also replaces the Proxy-Authorization header where
        necessary.
        s   Proxy-AuthorizationN(   NN(   RL   RO   R   RP   R!   RA   Rq   R   R   R/   t
   setdefaultR   R\   R   (   Rc   Ri   R>   RL   RO   RP   t   new_proxiest   environ_proxiest   proxyt   usernamet   password(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR`   å   s$    		
N(   t   __name__t
   __module__RI   R!   t   TrueRm   Ra   R`   (    (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR3   [   s   o	t   Sessionc           B   s  e  Z d  Z d d d d d d d d d	 d
 d d d g Z d „  Z d „  Z d „  Z d „  Z d! d! d! d! d! d! d! e	 d! d! d! d! d! d! d „ Z
 d „  Z d „  Z d „  Z d! d! d „ Z d! d „ Z d! d „ Z d „  Z d „  Z d „  Z d „  Z d „  Z d „  Z d „  Z d  „  Z RS("   sä   A Requests session.

    Provides cookie persistence, connection-pooling, and configuration.

    Basic Usage::

      >>> import requests
      >>> s = requests.Session()
      >>> s.get('http://httpbin.org/get')
      200
    RL   R^   t   authR>   t   hookst   paramsR<   R=   t   prefetcht   adaptersR:   Rq   RJ   c         C   s´   t  ƒ  |  _ d  |  _ i  |  _ t ƒ  |  _ i  |  _ t |  _	 t
 |  _ d  |  _ t |  _ t
 |  _ t i  ƒ |  _ t ƒ  |  _ |  j d t ƒ  ƒ |  j d t ƒ  ƒ t t ƒ |  _ d  S(   Ns   https://s   http://(   R   RL   R!   R€   R>   R   R   R‚   RI   R:   R~   R<   R=   R   RJ   Rq   R   R^   R   R„   t   mountR   R   t   REDIRECT_CACHE_SIZERT   (   Rc   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   __init__  s    								c         C   s   |  S(   N(    (   Rc   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt	   __enter__T  s    c         G   s   |  j  ƒ  d  S(   N(   RK   (   Rc   t   args(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   __exit__W  s    c         C   s*  | j  p i  } t | t j ƒ s0 t | ƒ } n  t t t ƒ  |  j  ƒ | ƒ } | j } |  j rƒ | rƒ |  j rƒ t	 | j
 ƒ } n  t ƒ  } | j d | j j ƒ  d | j
 d | j d | j d | j d t | j |  j d t ƒd t | j |  j ƒ d	 t | |  j ƒ d
 | d t | j |  j ƒ ƒ 
| S(   sb  Constructs a :class:`PreparedRequest <PreparedRequest>` for
        transmission and returns it. The :class:`PreparedRequest` has settings
        merged from the :class:`Request <Request>` instance and those of the
        :class:`Session`.

        :param request: :class:`Request` instance to prepare with this
            session's settings.
        RM   RO   t   filest   datat   jsonRL   R+   R‚   R€   R^   R   (   R^   R%   R   t	   CookieJarR   R
   R	   R€   Rq   R   RO   R   t   prepareRM   t   upperR‹   RŒ   R   R-   RL   R   R‚   R2   R   (   Rc   Ro   R^   t   merged_cookiesR€   t   p(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   prepare_requestZ  s*    								c         C   sÓ   t  | ƒ } t d | j ƒ  d | d | d | d | p9 i  d | d | pK i  d | d	 | d
 | ƒ 
} |  j | ƒ } | p{ i  } |  j | j | | | | ƒ } i |	 d 6|
 d 6} | j | ƒ |  j | |  } | S(   sC  Constructs a :class:`Request <Request>`, prepares it and sends it.
        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 json: (optional) json 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 ``'filename': file-like-objects``
            for multipart encoding upload.
        :param auth: (optional) Auth tuple or callable to enable
            Basic/Digest/Custom HTTP Auth.
        :param timeout: (optional) How long to wait for the server to send
            data before giving up, as a float, or a (`connect timeout, read
            timeout <user/advanced.html#timeouts>`_) tuple.
        :type timeout: float or tuple
        :param allow_redirects: (optional) Set to True by default.
        :type allow_redirects: bool
        :param proxies: (optional) Dictionary mapping protocol to the URL of
            the proxy.
        :param stream: (optional) whether to immediately download the response
            content. Defaults to ``False``.
        :param verify: (optional) if ``True``, the SSL cert will be verified.
            A CA_BUNDLE path can also be provided.
        :param cert: (optional) if String, path to ssl client cert file (.pem).
            If Tuple, ('cert', 'key') pair.
        RM   RO   RL   R‹   RŒ   R   R‚   R€   R^   R   R;   R?   (   R   R   R   R“   t   merge_environment_settingsRO   R&   Rb   (   Rc   RM   RO   R‚   RŒ   RL   R^   R‹   R€   R;   R?   R>   R   R:   R<   R=   R   Re   t   prept   settingst   send_kwargsRd   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyRo   ‚  s,    2	
c         K   s#   | j  d t ƒ |  j 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.
        R?   R7   (   Rv   R~   Ro   (   Rc   RO   t   kwargs(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR/   Õ  s    c         K   s#   | j  d t ƒ |  j 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(   Rv   R~   Ro   (   Rc   RO   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   optionsß  s    c         K   s#   | j  d t ƒ |  j 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?   R6   (   Rv   RI   Ro   (   Rc   RO   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   headé  s    c         K   s   |  j  d | 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 json: (optional) json to send in the body of the :class:`Request`.
        :param \*\*kwargs: Optional arguments that ``request`` takes.
        R8   RŒ   R   (   Ro   (   Rc   RO   RŒ   R   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   postó  s    	c         K   s   |  j  d | d | | S(   s7  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Œ   (   Ro   (   Rc   RO   RŒ   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   putþ  s    c         K   s   |  j  d | d | | S(   s9  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Œ   (   Ro   (   Rc   RO   RŒ   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   patch  s    c         K   s   |  j  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(   Ro   (   Rc   RO   R˜   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   delete  s    c         K   s  | j  d |  j ƒ | j  d |  j ƒ | j  d |  j ƒ | j  d |  j ƒ t | t ƒ sj t d ƒ ‚ n  t ƒ  } xT | j	 |  j
 k rÉ | j | j	 ƒ |  j
 j | j	 ƒ } | | k r½ Pn  | | _	 qv W| j d t ƒ } | j d ƒ } | j } |  j d | j	 ƒ } t j ƒ  }	 | j | |  }
 t j ƒ  |	 |
 _ t d | |
 |  }
 |
 j rˆx- |
 j D] } t |  j | j | j ƒ qbWn  t |  j | |
 j ƒ |  j |
 | |  } | rÒg  | D] } | ^ qÀn g  } | r| j d	 |
 ƒ | j ƒ  }
 | |
 _ n  | s|
 j n  |
 S(
   s   Send a given PreparedRequest.R:   R<   R=   R>   s#   You can only send PreparedRequests.R?   RO   R.   i    (   Rv   R:   R<   R=   R>   R%   R   t
   ValueErrort   setRO   RT   t   addR/   t   popR~   R   t   get_adapterR   t   utcnowRb   t   elapsedR   RD   R   R^   Ro   RG   Rm   t   insertRE   (   Rc   Ro   R˜   t   checked_urlst   new_urlR?   R:   R   t   adaptert   startt   rRd   t   genRD   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyRb     sD    			 %
c   	      C   sò   |  j  rŠ t | ƒ p i  } x* | j ƒ  D] \ } } | j | | ƒ q( W| t k s` | d k rŠ t j j d ƒ p t j j d ƒ } qŠ n  t	 | |  j
 ƒ } t	 | |  j ƒ } t	 | |  j ƒ } t	 | |  j ƒ } i | d 6| d 6| d 6| d 6S(   s6   Check the environment and merge it with some settings.t   REQUESTS_CA_BUNDLEt   CURL_CA_BUNDLER<   R>   R:   R=   N(   Rq   R   R'   Rv   R~   R!   t   ost   environR/   R-   R>   R:   R<   R=   (	   Rc   RO   R>   R:   R<   R=   t   env_proxiesR#   R$   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR”   a  s    	c         C   sM   x6 |  j  j ƒ  D]% \ } } | j ƒ  j | ƒ r | Sq Wt d | ƒ ‚ d S(   s>   Returns the appropriate connnection adapter for the given URL.s*   No connection adapters were found for '%s'N(   R„   R'   t   lowerRN   R   (   Rc   RO   t   prefixR­   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR§   y  s    c         C   s(   x! |  j  j ƒ  D] } | j ƒ  q Wd S(   s+   Closes all adapters and as such the sessionN(   R„   t   valuesRK   (   Rc   R$   (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyRK   ƒ  s    c         C   so   | |  j  | <g  |  j  D]$ } t | ƒ t | ƒ k  r | ^ q } x' | D] } |  j  j | ƒ |  j  | <qH Wd S(   sk   Registers a connection adapter to a prefix.

        Adapters are sorted in descending order by key length.N(   R„   t   lenR¦   (   Rc   R·   R­   R#   t   keys_to_movet   key(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR…   ˆ  s    4c            s6   t  ‡  f d †  ˆ  j Dƒ ƒ } t  ˆ  j ƒ | d <| S(   Nc         3   s'   |  ] } | t  ˆ  | d  ƒ f Vq d  S(   N(   t   getattrR!   (   R"   t   attr(   Rc   (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pys	   <genexpr>”  s    RT   (   R(   t	   __attrs__RT   (   Rc   t   state(    (   Rc   s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   __getstate__“  s    c         C   s|   | j  d i  ƒ } x* | j ƒ  D] \ } } t |  | | ƒ q Wt t ƒ |  _ x' | j ƒ  D] \ } } | |  j | <q[ Wd  S(   NRT   (   R¦   R'   t   setattrR   R†   RT   (   Rc   R¿   RT   R½   t   valuet   redirectt   to(    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   __setstate__˜  s    N(   R|   R}   t   __doc__R¾   R‡   Rˆ   RŠ   R“   R!   R~   Ro   R/   Rš   R›   Rœ   Rž   R    R¢   Rb   R”   R§   RK   R…   RÀ   RÅ   (    (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyR     sH   		6			)E	
	
	


			F		
			c           C   s   t  ƒ  S(   s2   Returns a :class:`Session` for context-management.(   R   (    (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   session¢  s    (6   RÆ   R³   t   collectionsR    R   R€   R   t   compatR   R   R   R   R^   R   R   R	   R
   t   modelsR   R   R   R   R   R   t   utilsR   R   R   t
   exceptionsR   R   R   R   t   packages.urllib3._collectionsR   t
   structuresR   R„   R   R   R   R   R   R   t   status_codesR   R    R†   R-   R2   t   objectR3   R   RÇ   (    (    (    s:   /tmp/pip-build-5Z5nTX/pip/pip/_vendor/requests/sessions.pyt   <module>
   s.   """(!°ÿ ˜