%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /usr/lib/python2.7/site-packages/urllib3/
Upload File :
Create Path :
Current File : //usr/lib/python2.7/site-packages/urllib3/poolmanager.pyc

�
nf�\c@@s�ddlmZddlZddlZddlZddlmZddlmZm	Z	ddlm
Z
ddlmZm
Z
mZddlmZdd	lmZdd
lmZddlmZddlmZd
ddgZeje�Zd6Zd7Zejd/e�Z d0�Z!iej"e!e �d16ej"e!e �d26Z#ied16e	d26Z$d
efd3��YZ%de%fd4��YZ&d5�Z'dS(8i(tabsolute_importNi(tRecentlyUsedContainer(tHTTPConnectionPooltHTTPSConnectionPool(tport_by_scheme(tLocationValueErrort
MaxRetryErrortProxySchemeUnknown(tsix(turljoin(tRequestMethods(t	parse_url(tRetrytPoolManagertProxyManagertproxy_from_urltkey_filet	cert_filet	cert_reqstca_certstssl_versiontca_cert_dirtssl_contextt
key_schemetkey_hosttkey_porttkey_timeouttkey_retriest
key_strictt	key_blocktkey_source_addresstkey_key_filet
key_cert_filet
key_cert_reqstkey_ca_certstkey_ssl_versiontkey_ca_cert_dirtkey_ssl_contexttkey_maxsizetkey_headerst
key__proxytkey__proxy_headerstkey_socket_optionstkey__socks_optionstkey_assert_hostnametkey_assert_fingerprinttkey_server_hostnametPoolKeycC@s|j�}|dj�|d<|dj�|d<xGdD]?}||kr;||d	k	r;t||j��||<q;q;W|jd�}|d	k	r�t|�|d<nx1t|j��D]}|j	|�|d|<q�Wx*|j
D]}||kr�d	||<q�q�W||�S(
s�
    Create a pool key out of a request context dictionary.

    According to RFC 3986, both the scheme and host are case-insensitive.
    Therefore, this function normalizes both before constructing the pool
    key for an HTTPS request. If you wish to change this behaviour, provide
    alternate callables to ``key_fn_by_scheme``.

    :param key_class:
        The class to use when constructing the key. This should be a namedtuple
        with the ``scheme`` and ``host`` keys at a minimum.
    :type  key_class: namedtuple
    :param request_context:
        A dictionary-like object that contain the context for a request.
    :type  request_context: dict

    :return: A namedtuple that can be used as a connection pool key.
    :rtype:  PoolKey
    tschemethosttheaderst_proxy_headerst_socks_optionstsocket_optionstkey_(R2R3R4N(tcopytlowertNonet	frozensettitemstgetttupletlisttkeystpopt_fields(t	key_classtrequest_contexttcontexttkeytsocket_optstfield((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt_default_key_normalizer;s
!thttpthttpscB@s�eZdZdZddd�Zd�Zd�Zdd�Zd�Z	dddd�Z
d	�Zdd
�Zdd�Z
d�Zed
�ZRS(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
cK@sMtj||�||_t|dd��|_t|_tj�|_dS(Ntdispose_funccS@s
|j�S(N(tclose(tp((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt<lambda>�t(R
t__init__tconnection_pool_kwRtpoolstpool_classes_by_schemetkey_fn_by_schemeR7(tselft	num_poolsR2RQ((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRP�s			cC@s|S(N((RU((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt	__enter__�scC@s|j�tS(N(tcleartFalse(RUtexc_typetexc_valtexc_tb((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt__exit__�s
cC@s�|j|}|dkr+|jj�}nxdD]}|j|d�q2W|dkr|x!tD]}|j|d�q_Wn||||�S(s�
        Create a new :class:`ConnectionPool` based on host, port, scheme, and
        any additional pool keyword arguments.

        If ``request_context`` is provided, it is provided as keyword arguments
        to the pool class used. 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.
        R0R1tportRIN(R0R1R^(RSR9RQR7R@tSSL_KEYWORDS(RUR0R1R^RCtpool_clsREtkw((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt	_new_pool�s



cC@s|jj�dS(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(RRRX(RU((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRX�sRIcC@sz|std��n|j|�}|p-d|d<|sYtj|dj�d�}n||d<||d<|j|�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``. If ``pool_kwargs`` is
        provided, it is merged with the instance's ``connection_pool_kw``
        variable and used to create the new connection pool, if one is
        needed.
        sNo host specified.RIR0iPR^R1(Rt_merge_pool_kwargsRR<R8tconnection_from_context(RUR1R^R0tpool_kwargsRC((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pytconnection_from_host�s

cC@s<|dj�}|j|}||�}|j|d|�S(s�
        Get a :class:`ConnectionPool` based on the request context.

        ``request_context`` must at least contain the ``scheme`` key and its
        value must be a key in ``key_fn_by_scheme`` instance variable.
        R0RC(R8RTtconnection_from_pool_key(RURCR0tpool_key_constructortpool_key((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRd�s
c
C@sy|jj�g|jj|�}|r)|S|d}|d}|d}|j|||d|�}||j|<WdQX|S(s�
        Get a :class:`ConnectionPool` based on the provided pool key.

        ``pool_key`` should be a namedtuple that only contains immutable
        objects. At a minimum it must have the ``scheme``, ``host``, and
        ``port`` fields.
        R0R1R^RCN(RRtlockR<Rb(RURiRCtpoolR0R1R^((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRg�s



cC@s4t|�}|j|jd|jd|jd|�S(s�
        Similar to :func:`urllib3.connectionpool.connection_from_url`.

        If ``pool_kwargs`` is not provided and a new pool needs to be
        constructed, ``self.connection_pool_kw`` is used to initialize
        the :class:`urllib3.connectionpool.ConnectionPool`. If ``pool_kwargs``
        is provided, it is used instead. Note that if a new pool does not
        need to be created for the request, the provided ``pool_kwargs`` are
        not used.
        R^R0Re(RRfR1R^R0(RUturlRetu((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pytconnection_from_urls!cC@sq|jj�}|rmxU|j�D]D\}}|dkr\y||=Wqftk
rXqfXq"|||<q"Wn|S(s
        Merge a dictionary of override values for self.connection_pool_kw.

        This does not modify self.connection_pool_kw and returns a new dict.
        Any keys in the override dictionary with a value of ``None`` are
        removed from the merged dictionary.
        N(RQR7R;R9tKeyError(RUtoverridetbase_pool_kwargsREtvalue((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRcs
cK@st|�}|j|jd|jd|j�}t|d<t|d<d|krf|jj�|d<n|jd
k	r�|jdkr�|j
|||�}n|j
||j|�}|o�|j�}|s�|St
||�}|jdkr�d}n|jd	�}	t|	t�s-tj|	d|�}	n|	jr�|j|�r�ttj|d��}
x=|
D]2}|j�|	jkrf|dj|d
�qfqfWny"|	j||d
|d|�}	Wn!tk
r�|	jr��n|SX|	|d	<||d<tjd||�|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^R0tassert_same_hosttredirectR2RIi/tGETtretriestresponset_poolsRedirecting %s -> %sN(RRfR1R^R0RYR2R7tproxyR9turlopentrequest_uritget_redirect_locationR	tstatusR<t
isinstanceRtfrom_inttremove_headers_on_redirecttis_same_hostR>RtiterkeysR8R@t	incrementRtraise_on_redirecttlogtinfo(RUtmethodRlRtRaRmtconnRwtredirect_locationRvR2theader((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRz/sD	$

		
"
	

N(t__name__t
__module__t__doc__R9RyRPRWR]RbRXRfRdRgRnRctTrueRz(((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyR
{s					
	cB@sJeZdZdddd�Zdddd�Zdd�Zed�ZRS(sx
    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 containing 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
cK@s�t|t�r.d|j|j|jf}nt|�}|jsmtj|jd�}|jd|�}n|jdkr�t	|j��n||_
|p�i|_|j
|d<|j|d<tt
|�j|||�dS(	Ns
%s://%s:%iiPR^RIRJt_proxyR3(RIRJ(R~RR0R1R^RRR<t_replaceRRyt
proxy_headerstsuperRRP(RUt	proxy_urlRVR2R�RQRyR^((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRP�s		

RIcC@sb|dkr.tt|�j|||d|�Stt|�j|jj|jj|jjd|�S(NRJRe(R�RRfRyR1R^R0(RUR1R^R0Re((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRf�s
cC@sIidd6}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*/*tAccepttHost(Rtnetloctupdate(RURlR2theaders_R�((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt_set_proxy_headers�s

cK@skt|�}|jdkrI|jd|j�}|j||�|d<ntt|�j||d||�S(s@Same as HTTP(S)ConnectionPool.urlopen, ``url`` must be absolute.RIR2Rt(RR0R<R2R�R�RRz(RUR�RlRtRaRmR2((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRz�s
N(	R�R�R�R9RPRfR�R�Rz(((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyRmscK@std||�S(NR�(R(RlRa((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyR�s(RRRRRRR(RRRRRRRRRR R!R"R#R$R%R&R'R(R)R*R+R,R-R.((t
__future__Rtcollectionst	functoolstloggingt_collectionsRtconnectionpoolRRRt
exceptionsRRRtpackagesRtpackages.six.moves.urllib.parseR	trequestR
tutil.urlRt
util.retryRt__all__t	getLoggerR�R�R_t_key_fieldst
namedtupleR/RHtpartialRTRSR
RR(((s7/usr/lib/python2.7/site-packages/urllib3/poolmanager.pyt<module>sf	5
�W

Zerion Mini Shell 1.0