^c@s(dZddlZddlZddlZddlmZddlmZddlm Z ddl m Z m Z m Z mZmZddlmZmZmZmZdd lmZmZmZdd lmZmZdd lmZdd lmZm Z m!Z!dd l"m#Z#m$Z$m%Z%m&Z&ddl'm(Z(ddl)m*Z*ddlm+Z+m,Z,m-Z-m.Z.m/Z/m0Z0ddl1m2Z2ddlm3Z3ej4dkry ej5Z6Wne7k rej8Z6nXn ejZ6edZ9edZ:de;fdYZ<de<fdYZ=dZ>dS(s requests.session ~~~~~~~~~~~~~~~~ This module provides a Session object to manage and persist settings across requests (cookies, auth, proxies). iN(t timedelta(t OrderedDicti(t_basic_auth_str(t cookielibtis_py3turljointurlparsetMapping(tcookiejar_from_dicttextract_cookies_to_jartRequestsCookieJart merge_cookies(tRequesttPreparedRequesttDEFAULT_REDIRECT_LIMIT(t default_hookst dispatch_hook(tto_native_string(tto_key_val_listtdefault_headerst DEFAULT_PORTS(tTooManyRedirectst InvalidSchematChunkedEncodingErrortContentDecodingError(tCaseInsensitiveDict(t HTTPAdapter(t requote_uritget_environ_proxiestget_netrc_authtshould_bypass_proxiestget_auth_from_urlt rewind_body(tcodes(tREDIRECT_STATItwin32cCs|dkr|S|dkr |St|to;t|tsB|S|t|}|jt|g|jD]\}}|dkrt|^qt}x|D] }||=qW|S(sDetermines 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` N(tNonet isinstanceRRtupdatetitems(trequest_settingtsession_settingt dict_classtmerged_settingtktvt none_keystkey((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt merge_setting2s  1  cCsZ|dks!|jdgkr%|S|dksF|jdgkrJ|St|||S(sProperly merges both requests and session hooks. This is necessary because when request_hooks == {'response': []}, the merge breaks Session hooks entirely. tresponseN(R$tgetR0(t request_hookst session_hooksR*((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt merge_hooksQs !!tSessionRedirectMixincBsPeZdZdZededdedZdZdZ dZ RS(cCs?|jr;|jd}tr.|jd}nt|dSdS(s7Receives a Response. Returns a redirect URI or ``None``tlocationtlatin1tutf8N(t is_redirecttheadersRtencodeRR$(tselftrespR7((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytget_redirect_targetbs    cCst|}t|}|j|jkr.tS|jdkrn|jdkrn|jdkrn|jdkrntS|j|jk}|j|jk}tj|jddf}| r|j|kr|j|krtS|p|S(sFDecide whether Authorization header should be removed when redirectingthttpiPthttpsiN(iPN(iN( RthostnametTruetschemetportR$tFalseRR2(R=told_urltnew_urlt old_parsedt new_parsedt changed_porttchanged_schemet default_port((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytshould_strip_authws  c ks4g} |j|} t|jj} x| r/|j} | j|| d|_y |jWn-tt t fk r|j j dt nXt|j|jkrtdj|jd|n|j| jdrt|j}djt|j| g} nt| }|jdkrI| rI|jd| }n|jr^|j} n|j} |jst|jt| } n t| } t| | _|j| ||jtjtj fkr d}x!|D]}| j!j"|dqWd| _$n| j!}|j"d dt%| j&||j t'| j&|j(| j)| j&|j*| |}|j+| || j,dk od |kpd |k}|rt-| n| }|r|Vq*|j.|d |d|d|d|d|dt | }t%|j(| |j |j|} |Vq*WdS(sBReceives a Response. Returns a generator of Responses or Requests.itdecode_contentsExceeded {} redirects.R1s//t:ttfragmentsContent-Lengths Content-TypesTransfer-EncodingtCookietstreamttimeouttverifytcerttproxiestallow_redirectsN(sContent-Lengths Content-TypesTransfer-Encoding(/R?RturlRRtcopytappendthistorytcontentRRt RuntimeErrortrawtreadRFtlent max_redirectsRtformattcloset startswithtjoinRRDt_replacetgeturltnetlocRRtrebuild_methodt status_codeR!ttemporary_redirecttpermanent_redirectR;tpopR$tbodyR t_cookiesR tcookiestprepare_cookiestrebuild_proxiest rebuild_autht_body_positionR tsend(R=R>treqRTRURVRWRXtyield_requeststadapter_kwargsthistRZtprevious_fragmenttprepared_requestt parsed_rurltparsedtpurged_headerstheaderR;t rewindable((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytresolve_redirectssv     ! !           cCs{|j}|j}d|kr@|j|jj|r@|d=n|jrUt|nd}|dk rw|j|ndS(sWhen 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(R;RZRNtrequestt trust_envRR$t prepare_auth(R=R}R1R;RZtnew_auth((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRus  $  c Cs5|dk r|ni}|j}|j}t|j}|j}|jd}t|d|}|jr| rt |d|} | j|| jd} | r|j || qnd|kr|d=nyt ||\} } Wnt k rd\} } nX| r1| r1t | | |d>> import requests >>> s = requests.Session() >>> s.get('https://httpbin.org/get') Or as a context manager:: >>> with requests.Session() as s: ... s.get('https://httpbin.org/get') R;RrtauthRXthookstparamsRVRWtadaptersRTRRccCst|_d|_i|_t|_i|_t|_ t |_ d|_ t |_t |_ti|_t|_|jdt|jdtdS(Nshttps://shttp://(RR;R$RRXRRRRFRTRCRVRWRRcRRRrRRtmountR(R=((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt__init__js           cCs|S(N((R=((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt __enter__scGs|jdS(N(Re(R=targs((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt__exit__scCs*|jp i}t|tjs0t|}nttt|j|}|j}|jr| r|j rt |j }nt }|j d|j jd|j d|jd|jd|jdt|j|jdtdt|j|jd t||jd |d t|j|j |S( sConstructs a :class:`PreparedRequest ` for transmission and returns it. The :class:`PreparedRequest` has settings merged from the :class:`Request ` instance and those of the :class:`Session`. :param request: :class:`Request` instance to prepare with this session's settings. :rtype: requests.PreparedRequest RRZtfilestdatatjsonR;R*RRRrR(RrR%Rt CookieJarRR R RRRRZR tprepareRtupperRRRR0R;RRR5R(R=RRrtmerged_cookiesRtp((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytprepare_requests*        cCstd|jd|d|d|d|p-id|d|p?id|d |d | }|j|}| poi} |j|j| | ||}i| d 6| d 6}|j||j||}|S( sConstructs a :class:`Request `, prepares it and sends it. Returns :class:`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, list of tuples, 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 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 :ref:`(connect timeout, read timeout) ` 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 or protocol and hostname to the URL of the proxy. :param stream: (optional) whether to immediately download the response content. Defaults to ``False``. :param verify: (optional) Either a boolean, in which case it controls whether we verify the server's TLS certificate, or a string, in which case it must be a path to a CA bundle to use. Defaults to ``True``. :param cert: (optional) if String, path to ssl client cert file (.pem). If Tuple, ('cert', 'key') pair. :rtype: requests.Response RRZR;RRRRRRrRRURY(R RRtmerge_environment_settingsRZR&Rw(R=RRZRRR;RrRRRURYRXRRTRVRWRRxtpreptsettingst send_kwargsR>((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRs*)       cKs#|jdt|jd||S(sSends a GET request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response RYR(RRCR(R=RZtkwargs((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyR2scKs#|jdt|jd||S(sSends a OPTIONS request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response RYtOPTIONS(RRCR(R=RZR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytoptions!scKs#|jdt|jd||S(sSends a HEAD request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response RYR(RRFR(R=RZR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pythead,scKs|jd|d|d||S(sSends a POST request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, 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. :rtype: requests.Response RRR(R(R=RZRRR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytpost7s cKs|jd|d||S(suSends a PUT request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the :class:`Request`. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response tPUTR(R(R=RZRR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytputDs cKs|jd|d||S(swSends a PATCH request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param data: (optional) Dictionary, list of tuples, bytes, or file-like object to send in the body of the :class:`Request`. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response tPATCHR(R(R=RZRR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytpatchPs cKs|jd||S(sSends a DELETE request. Returns :class:`Response` object. :param url: URL for the new :class:`Request` object. :param \*\*kwargs: Optional arguments that ``request`` takes. :rtype: requests.Response tDELETE(R(R=RZR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytdelete\sc Ks|jd|j|jd|j|jd|j|jd|jt|trjtdn|jdt }|j d}|j }|j d|j }t}|j||}t|} td| |_td |||}|jr1x-|jD]} t|j| j| jq Wnt|j||j|j|||} |r{g| D]} | ^qing} | r| jd || j}| |_n|sy(t|j||d t ||_Wqtk rqXn|s|jn|S( sISend a given PreparedRequest. :rtype: requests.Response RTRVRWRXs#You can only send PreparedRequests.RYRZtsecondsR1iRy(RRTRVRWRXR%R t ValueErrorRoRCR2Rt get_adapterRZtpreferred_clockRwRtelapsedRR]R RrRR`Rtinserttnextt_nextt StopIterationR^( R=RRRYRTRtadaptertstarttrRR>tgenR]((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRwfsB     %  (  c Cs|jr|dk r$|jdnd}t|d|}x*|jD]\}} |j|| qIW|tks|dkrtjjdptjjd}qnt ||j }t ||j }t ||j }t ||j }i|d6|d6|d6|d6S( s^ Check the environment and merge it with some settings. :rtype: dict RtREQUESTS_CA_BUNDLEtCURL_CA_BUNDLERVRXRTRWN(RR$R2RR'RRCtostenvironR0RXRTRVRW( R=RZRXRTRVRWRt env_proxiesR,R-((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRs !cCsXx<|jjD]+\}}|jj|jr|SqWtdj|dS(s~ Returns the appropriate connection adapter for the given URL. :rtype: requests.adapters.BaseAdapter s*No connection adapters were found for {!r}N(RR'tlowerRfRRd(R=RZtprefixR((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRscCs(x!|jjD]}|jqWdS(s+Closes all adapters and as such the sessionN(RtvaluesRe(R=R-((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRescCso||j|s (t __attrs__(R=tstate((R=s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt __getstate__scCs1x*|jD]\}}t|||q WdS(N(R'tsetattr(R=RRtvalue((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt __setstate__sN(RRt__doc__RRRRRR$RCRR2RRRRRRRwRRReRRR(((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyRQs2   7   ) D  I    cCstS(sZ Returns a :class:`Session` for context-management. .. deprecated:: 1.0.0 This method has been deprecated since version 1.0.0 and is only kept for backwards compatibility. New code should use :class:`~requests.sessions.Session` to create a session. This may be removed at a future date. :rtype: Session (R(((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pytsessions (?RRtsysttimetdatetimeRt collectionsRRRtcompatRRRRRRrRR R R tmodelsR R RRRRt_internal_utilsRtutilsRRRt exceptionsRRRRt structuresRRRRRRRRR t status_codesR!R"tplatformt perf_counterRtAttributeErrortclockR0R5tobjectR6RR(((s3/tmp/pip-build-1THPZW/requests/requests/sessions.pyt s<   ("".