σ
^κWc           @@  sG  d  d l  m Z d  d l Z y d  d l m Z Wn! e k
 rS d  d l m Z n Xd d l m Z d d l	 m
 Z
 m Z d d l	 m Z d d l m Z m Z m Z d d	 l m Z d d
 l m Z d d l m Z d d d g Z e j e  Z d Z i e
 d 6e d 6Z d e f d     YZ d e f d     YZ d   Z d S(   i    (   t   absolute_importN(   t   urljoini   (   t   RecentlyUsedContainer(   t   HTTPConnectionPoolt   HTTPSConnectionPool(   t   port_by_scheme(   t   LocationValueErrort   MaxRetryErrort   ProxySchemeUnknown(   t   RequestMethods(   t	   parse_url(   t   Retryt   PoolManagert   ProxyManagert   proxy_from_urlt   key_filet	   cert_filet	   cert_reqst   ca_certst   ssl_versiont   ca_cert_dirt   httpt   httpsc           B@  sk   e  Z d  Z d Z d d d  Z d   Z d   Z d   Z d   Z	 d d d  Z
 d	   Z e d
  Z RS(   s$  
    Allows for arbitrary requests while transparently keeping track of
    necessary connection pools for you.

    :param num_pools:
        Number of connection pools to cache before discarding the least
        recently used pool.

    :param headers:
        Headers to include with all requests, unless other headers are given
        explicitly.

    :param \**connection_pool_kw:
        Additional parameters are used to create fresh
        :class:`urllib3.connectionpool.ConnectionPool` instances.

    Example::

        >>> manager = PoolManager(num_pools=2)
        >>> r = manager.request('GET', 'http://google.com/')
        >>> r = manager.request('GET', 'http://google.com/mail')
        >>> r = manager.request('GET', 'http://yahoo.com/')
        >>> len(manager.pools)
        2

    i
   c         K@  s>   t  j |  |  | |  _ t | d d   |  _ t |  _ d  S(   Nt   dispose_funcc         S@  s
   |  j    S(   N(   t   close(   t   p(    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   <lambda>B   s    (   R	   t   __init__t   connection_pool_kwR   t   poolst   pool_classes_by_scheme(   t   selft	   num_poolst   headersR   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR   >   s
    		c         C@  s   |  S(   N(    (   R   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt	   __enter__G   s    c         C@  s   |  j    t S(   N(   t   cleart   False(   R   t   exc_typet   exc_valt   exc_tb(    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   __exit__J   s    
c         C@  se   |  j  | } |  j } | d k rU |  j j   } x! t D] } | j | d  q8 Wn  | | | |  S(   s  
        Create a new :class:`ConnectionPool` based on host, port and scheme.

        This method is used to actually create the connection pools handed out
        by :meth:`connection_from_url` and companion methods. It is intended
        to be overridden for customization.
        R   N(   R   R   t   copyt   SSL_KEYWORDSt   popt   None(   R   t   schemet   hostt   portt   pool_clst   kwargst   kw(    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt	   _new_poolO   s    	c         C@  s   |  j  j   d S(   s΄   
        Empty our store of pools and direct them all to close.

        This will not affect in-flight connections, but they will not be
        re-used after completion.
        N(   R   R#   (   R   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR#   `   s    R   c         C@  s   | s t  d   n  | p d } | p6 t j | d  } | | | f } |  j j C |  j j |  } | rq | S|  j | | |  } | |  j | <Wd QX| S(   sΦ   
        Get a :class:`ConnectionPool` based on the host, port, and scheme.

        If ``port`` isn't given, it will be derived from the ``scheme`` using
        ``urllib3.connectionpool.port_by_scheme``.
        s   No host specified.R   iP   N(   R   R   t   getR   t   lockR3   (   R   R.   R/   R-   t   pool_keyt   pool(    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   connection_from_hosti   s    c         C@  s.   t  |  } |  j | j d | j d | j S(   s*  
        Similar to :func:`urllib3.connectionpool.connection_from_url` but
        doesn't pass any additional parameters to the
        :class:`urllib3.connectionpool.ConnectionPool` constructor.

        Additional parameters are taken from the :class:`.PoolManager`
        constructor.
        R/   R-   (   R
   R8   R.   R/   R-   (   R   t   urlt   u(    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   connection_from_url   s    	c   
      K@  s§  t  |  } |  j | j d | j d | j } t | d <t | d <d | k r` |  j | d <n  |  j d k	 r | j d k r | j	 | | |  } n | j	 | | j
 |  } | o½ | j   } | sΚ | St | |  } | j d k rρ d } n  | j d	  }	 t |	 t  s't j |	 d | }	 n  y" |	 j | | d
 | d | }	 Wn! t k
 rl|	 j rh  n  | SX|	 | d	 <| | d <t j d | |  |  j	 | | |  S(   s]  
        Same as :meth:`urllib3.connectionpool.HTTPConnectionPool.urlopen`
        with custom cross-host redirect logic and only sends the request-uri
        portion of the ``url``.

        The given ``url`` parameter must be absolute, such that an appropriate
        :class:`urllib3.connectionpool.ConnectionPool` can be chosen for it.
        R/   R-   t   assert_same_hostt   redirectR!   R   i/  t   GETt   retriest   responset   _pools   Redirecting %s -> %sN(   R
   R8   R.   R/   R-   R$   R!   t   proxyR,   t   urlopent   request_urit   get_redirect_locationR   t   statusR4   t
   isinstanceR   t   from_intt	   incrementR   t   raise_on_redirectt   logt   info(
   R   t   methodR9   R=   R2   R:   t   connR@   t   redirect_locationR?   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyRC      s8    	$

	"	

N(   t   __name__t
   __module__t   __doc__R,   RB   R   R"   R(   R3   R#   R8   R;   t   TrueRC   (    (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR       s   							c           B@  sG   e  Z d  Z d d d d  Z d d d  Z d d  Z e d  Z RS(   sw  
    Behaves just like :class:`PoolManager`, but sends all requests through
    the defined proxy, using the CONNECT method for HTTPS URLs.

    :param proxy_url:
        The URL of the proxy to be used.

    :param proxy_headers:
        A dictionary contaning headers that will be sent to the proxy. In case
        of HTTP they are being sent with each request, while in the
        HTTPS/CONNECT case they are sent only once. Could be used for proxy
        authentication.

    Example:
        >>> proxy = urllib3.ProxyManager('http://localhost:3128/')
        >>> r1 = proxy.request('GET', 'http://google.com/')
        >>> r2 = proxy.request('GET', 'http://httpbin.org/')
        >>> len(proxy.pools)
        1
        >>> r3 = proxy.request('GET', 'https://httpbin.org/')
        >>> r4 = proxy.request('GET', 'https://twitter.com/')
        >>> len(proxy.pools)
        3

    i
   c         K@  sΰ   t  | t  r. d | j | j | j f } n  t |  } | j sm t j | j d  } | j d |  } n  | j d k r t	 | j   n  | |  _
 | p  i  |  _ |  j
 | d <|  j | d <t t |   j | | |  d  S(	   Ns
   %s://%s:%iiP   R/   R   R   t   _proxyt   _proxy_headers(   s   https   https(   RG   R   R-   R.   R/   R
   R   R4   t   _replaceR   RB   t   proxy_headerst   superR   R   (   R   t	   proxy_urlR    R!   RW   R   RB   R/   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR   ί   s    		R   c         C@  sV   | d k r( t  t |   j | | |  St  t |   j |  j j |  j j |  j j  S(   NR   (   RX   R   R8   RB   R.   R/   R-   (   R   R.   R/   R-   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR8   φ   s
    c         C@  sI   i d d 6} t  |  j } | r/ | | d <n  | rE | j |  n  | S(   s   
        Sets headers needed by proxies: specifically, the Accept and Host
        headers. Only sets headers not provided by the user.
        s   */*t   Acceptt   Host(   R
   t   netloct   update(   R   R9   R!   t   headers_R\   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   _set_proxy_headersώ   s    c         K@  sk   t  |  } | j d k rI | j d |  j  } |  j | |  | d <n  t t |   j | | d | | S(   s@   Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute.R   R!   R=   (   R
   R-   R4   R!   R_   RX   R   RC   (   R   RM   R9   R=   R2   R:   R!   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyRC     s
    N(	   RP   RQ   RR   R,   R   R8   R_   RS   RC   (    (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR   Δ   s   c         K@  s   t  d |  |  S(   NRY   (   R   (   R9   R2   (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyR     s    (   s   key_files	   cert_files	   cert_reqss   ca_certss   ssl_versions   ca_cert_dir(    t
   __future__R    t   loggingt   urllib.parseR   t   ImportErrort   urlparset   _collectionsR   t   connectionpoolR   R   R   t
   exceptionsR   R   R   t   requestR	   t   util.urlR
   t
   util.retryR   t   __all__t	   getLoggerRP   RK   R*   R   R   R   R   (    (    (    s   /private/var/folders/3n/6h2rwf155rn1m71wwyxn79n80000gn/T/pip-build-IcAT_k/pip/pip/_vendor/requests/packages/urllib3/poolmanager.pyt   <module>   s,    
€W