ó
ú—7Tc           @   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 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& m' Z' m( Z( m) Z) m* Z* d d l+ m, Z, d d l m- Z- e	 d „ Z. e	 d „ Z/ d e0 f d „  ƒ  YZ1 d e1 f d „  ƒ  YZ2 d „  Z3 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   urlparset   builtin_str(   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   CaseInsensitiveDict(   t   HTTPAdapter(   t   requote_urit   get_environ_proxiest   get_netrc_autht   should_bypass_proxiest   get_auth_from_url(   t   codes(   t   REDIRECT_STATIc         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(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pys	   <genexpr>C   s    N(   R!   t
   isinstanceR    R   t   updatet   itemst   dict(   t   request_settingt   session_settingt
   dict_classt   merged_settingR#   R$   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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+   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   merge_hooksH   s
    !!t   SessionRedirectMixinc           B   s2   e  Z e d e d d d  „ Z d „  Z d „  Z RS(   c         c   sÙ  d } xÌ| j  rÔ| j ƒ  }	 y | j Wn- t t t f k
 rX | 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 ƒ  }
 t |
 ƒ j st | j t |
 ƒ ƒ }
 n t |
 ƒ }
 t |
 ƒ |	 _ | j t j k rV| d k rV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 rðd
 |	 j k rä|	 j d
 =n  d |	 _ n  |	 j } y | d =Wn t  k
 r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   contentR   R   t   RuntimeErrort   rawt   readt   Falset   max_redirectsR   t   closet   headerst   methodt
   startswithR   t   urlt   schemet   geturlt   netlocR   R   R   t   status_codeR   t	   see_othert   foundt   movedt	   temporaryt   resumeR!   t   bodyt   KeyErrorR	   t   _cookiesR&   t   cookiest   prepare_cookiest   rebuild_proxiest   rebuild_autht   send(   t   selft   respt   reqR:   R;   R<   R=   R>   t   it   prepared_requestRL   RJ   t   parsed_rurlt   parsedRI   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   resolve_redirectsY   sn    
							
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(	   RI   RL   R   t   requestt   hostnamet	   trust_envR   R!   t   prepare_auth(   R^   Rb   R.   RI   RL   t   original_parsedt   redirect_parsedt   new_auth(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyR\   »   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(   RI   RL   R   RM   R!   RA   Ri   R   R   R/   t
   setdefaultR   RW   R   (   R^   Rb   R>   RI   RL   RM   t   new_proxiest   environ_proxiest   proxyt   usernamet   password(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyR[   Ô   s$    		
N(   t   __name__t
   __module__RF   R!   t   TrueRe   R\   R[   (    (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyR3   X   s   a	t   Sessionc           B   s  e  Z d  Z d 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 „ Z
 d „  Z d „  Z d „  Z d! d „ Z d! d „ Z d! 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
    RI   RY   t   authR;   R>   t   hookst   paramsR<   R=   t   prefetcht   adaptersR:   Ri   RG   c         C   s¥   t  ƒ  |  _ d  |  _ i  |  _ t ƒ  |  _ i  |  _ t |  _	 t
 |  _ d  |  _ t |  _ t
 |  _ t i  ƒ |  _ t ƒ  |  _ |  j d t ƒ  ƒ |  j d t ƒ  ƒ d  S(   Ns   https://s   http://(   R   RI   R!   Rx   R>   R   Ry   Rz   RF   R:   Rv   R<   R=   R   RG   Ri   R   RY   R   R|   t   mountR   (   R^   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   __init__  s    								c         C   s   |  S(   N(    (   R^   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt	   __enter__?  s    c         G   s   |  j  ƒ  d  S(   N(   RH   (   R^   t   args(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   __exit__B  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 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.
        RJ   RL   t   filest   dataRI   R+   Rz   Rx   RY   Ry   (   RY   R%   R   t	   CookieJarR   R   R
   Rx   Ri   R   RL   R   t   prepareRJ   t   upperR‚   Rƒ   R-   RI   R   Rz   R2   Ry   (   R^   Rg   RY   t   merged_cookiesRx   t   p(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   prepare_requestE  s(    							c         C   s¡  t  | ƒ } t d | j ƒ  d | d | d | d | p9 i  d | pE i  d | d | d	 | ƒ 	} |  j | ƒ } | pu i  } |  j rt | ƒ p i  } x* | j ƒ  D] \ } } | j | | ƒ q  W| rè | t k	 rè t	 j
 j d
 ƒ } n  | r| t k	 rt	 j
 j d ƒ } qn  t | |  j ƒ } t | |  j ƒ } t | |  j ƒ } t | |  j ƒ } i | d 6|	 d 6| d 6| d 6| d 6|
 d 6} |  j | |  } | S(   s4  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 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) Float describing the timeout of the
            request in seconds.
        :param allow_redirects: (optional) Boolean. Set to True by default.
        :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.
        RJ   RL   RI   R‚   Rƒ   Rz   Rx   RY   Ry   t   REQUESTS_CA_BUNDLEt   CURL_CA_BUNDLER:   R;   R<   R=   R>   R?   (   R   R   R†   R‰   Ri   R   R'   Rn   RF   t   ost   environR/   R-   R>   R:   R<   R=   R]   (   R^   RJ   RL   Rz   Rƒ   RI   RY   R‚   Rx   R;   R?   R>   Ry   R:   R<   R=   R`   t   prept   env_proxiesR#   R$   t   send_kwargsR_   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyRg   l  sD    ,		
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   (   Rn   Rv   Rg   (   R^   RL   t   kwargs(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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(   Rn   Rv   Rg   (   R^   RL   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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   (   Rn   RF   Rg   (   R^   RL   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   headà  s    c         K   s   |  j  d | d | | S(   s8  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.
        R8   Rƒ   (   Rg   (   R^   RL   Rƒ   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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ƒ   (   Rg   (   R^   RL   Rƒ   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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ƒ   (   Rg   (   R^   RL   Rƒ   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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(   Rg   (   R^   RL   R‘   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/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  | j d t	 ƒ } | j
 d ƒ } | j
 d ƒ } | j
 d ƒ } | j
 d ƒ } | j
 d ƒ } | j }	 |  j d | j ƒ }
 t j ƒ  } |
 j | |  } t j ƒ  | | _ t d	 |	 | |  } | j rdx- | j D] } t |  j | j | j ƒ q>Wn  t |  j | | j ƒ |  j | | d | d | d | d | d | ƒ} | 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?   R;   RL   R.   i    (   Rn   R:   R<   R=   R>   R%   R   t
   ValueErrort   popRv   R/   Ry   t   get_adapterRL   R   t   utcnowR]   t   elapsedR   t   historyR	   RY   Rg   RD   Re   t   insertRB   (   R^   Rg   R‘   R?   R:   R;   R<   R=   R>   Ry   t   adaptert   startt   rR_   t   genR¡   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyR]     sH    		 	%
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   lowerRK   R   (   R^   RL   t   prefixR£   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyRž   X  s    c         C   s(   x! |  j  j ƒ  D] } | j ƒ  q Wd S(   s+   Closes all adapters and as such the sessionN(   R|   t   valuesRH   (   R^   R$   (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyRH   b  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   (   R^   R¨   R£   R#   t   keys_to_movet   key(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyR}   g  s    4c            s   t  ‡  f d †  ˆ  j Dƒ ƒ S(   Nc         3   s'   |  ] } | t  ˆ  | d  ƒ f Vq d  S(   N(   t   getattrR!   (   R"   t   attr(   R^   (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pys	   <genexpr>s  s    (   R(   t	   __attrs__(   R^   (    (   R^   sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   __getstate__r  s    c         C   s1   x* | j  ƒ  D] \ } } t |  | | ƒ q Wd  S(   N(   R'   t   setattr(   R^   t   stateR®   t   value(    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   __setstate__u  s    N(   Rt   Ru   t   __doc__R¯   R~   R   R   R‰   R!   Rv   Rg   R/   R“   R”   R•   R—   R™   R›   R]   Rž   RH   R}   R°   R´   (    (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyRw   ú   sD   	3			(S	
	
	



			G	
			c           C   s   t  ƒ  S(   s2   Returns a :class:`Session` for context-management.(   Rw   (    (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   sessionz  s    (4   Rµ   RŒ   t   collectionsR    R   Rx   R   t   compatR   R   R   R   R   RY   R   R	   R
   R   t   modelsR   R   R   Ry   R   R   t   utilsR   R   R   t
   exceptionsR   R   R   R   t
   structuresR   R|   R   R   R   R   R   R   t   status_codesR   R    R-   R2   t   objectR3   Rw   R¶   (    (    (    sL   /var/www/otrsdash.zarafa.com/venv/build/pip/pip/_vendor/requests/sessions.pyt   <module>
   s*   (""(!¢ÿ 