ž 7’ReDgc@s;dZddlZddlZddlmZmZddlmZddlm Z ddl m Z ddl m Z mZdd lmZdd lmZdd lmZdd lmZdd lmZmZmZmZmZmZddlmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(ddl)m*Z*m+Z+m,Z,m-Z-m.Z.m/Z/m0Z0m1Z1m2Z2m3Z3m4Z4m5Z5m6Z6ddl7m8Z8e8j9e8j:e8j;e8j<fZ=dZ>dZ?dZ@Gdd„deAƒZBGdd„deAƒZCGdd„deCƒZDGdd„deBeCƒZEGdd„deAƒZFdS( u` requests.models ~~~~~~~~~~~~~~~ This module contains the primary objects that power Requests. iN(uBytesIOuUnsupportedOperationi(u default_hooks(uCaseInsensitiveDict(u HTTPBasicAuth(ucookiejar_from_dictuget_cookie_header(u RequestField(uencode_multipart_formdata(u parse_url(u DecodeError(u HTTPErroruRequestExceptionu MissingSchemau InvalidURLuChunkedEncodingErroruContentDecodingError( uguess_filenameuget_auth_from_urlu requote_uriustream_decode_response_unicodeuto_key_val_listuparse_header_linksu iter_slicesuguess_json_utfu super_lenuto_native_string( u cookielibu urlunparseuurlsplitu urlencodeustrubytesuStringIOuis_py2uchardetujsonu builtin_stru basestringuIncompleteRead(ucodesii iicBsJ|EeZdZedd„ƒZedd„ƒZedd„ƒZdS(uRequestEncodingMixincCssg}t|jƒ}|j}|s-d}n|j|ƒ|j}|rf|jdƒ|j|ƒndj|ƒS(uBuild the path URL to use.u/u?u(uurlsplituurlupathuappenduqueryujoin(uselfuurlupupathuquery((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyupath_url1s     uRequestEncodingMixin.path_urlcCst|ttfƒr|St|dƒr,|St|dƒrg}x´t|ƒD]¦\}}t|tƒsyt|dƒ r…|g}nxl|D]d}|dk rŒ|jt|tƒrÂ|jdƒn|t|tƒrã|jdƒn|fƒqŒqŒWqNWt |ddƒS|SdS(uüEncode parameters in a piece of data. Will successfully encode parameters when passed as a dict or a list of 2-tuples. Order is retained if data is a list of 2-tuples but arbitrary if parameters are supplied as a dict. ureadu__iter__uutf-8udoseqNT( u isinstanceustrubytesuhasattruto_key_val_listu basestringuNoneuappenduencodeu urlencodeuTrue(udatauresultukuvsuv((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu_encode_paramsFs    !3u#RequestEncodingMixin._encode_paramsc Csr|stdƒ‚nt|tƒr3tdƒ‚ng}t|pEiƒ}t|pWiƒ}xÌ|D]Ä\}}t|tƒst|dƒ r›|g}nxŠ|D]‚}|d k r¢t|tƒsÒt|ƒ}n|jt|tƒrö|j dƒn|t|tƒr|j dƒn|fƒq¢q¢WqdWx'|D]\}}d }d } t|t t fƒrºt |ƒdkr|\} } qÒt |ƒdkr¥|\} } }qÒ|\} } }} nt|ƒpÉ|} |} t| tƒrðt| ƒ} nt| tƒrt| ƒ} ntd|d| jƒd | d | ƒ} | jd |ƒ|j| ƒq3Wt|ƒ\} }| |fS( uBuild the body for a multipart/form-data request. Will successfully encode files when passed as a dict or a list of 2-tuples. Order is retained if data is a list of 2-tuples but arbitrary if parameters are supplied as a dict. uFiles must be provided.uData must not be a string.u__iter__uutf-8iiunameudataufilenameuheadersu content_typeN(u ValueErroru isinstanceu basestringuto_key_val_listuhasattruNoneubytesustruappendudecodeuencodeutupleulistulenuguess_filenameuStringIOuBytesIOu RequestFieldureadumake_multipartuencode_multipart_formdata(ufilesudatau new_fieldsufieldsufielduvaluvukuftufhufnufpurfubodyu content_type((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu _encode_filesasL    !3u"RequestEncodingMixin._encode_filesN(u__name__u __module__u __qualname__upropertyupath_urlu staticmethodu_encode_paramsu _encode_files(u __locals__((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuRequestEncodingMixin0suRequestEncodingMixincBs,|EeZdZdd„Zdd„ZdS(uRequestHooksMixincCs‚||jkr"td|ƒ‚nt|tjƒrK|j|j|ƒn3t|dƒr~|j|jdd„|DƒƒndS(uProperly register a hook.u1Unsupported event specified, with event name "%s"u__iter__css'|]}t|tjƒr|VqdS(N(u isinstanceu collectionsuCallable(u.0uh((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu §su2RequestHooksMixin.register_hook..N(uhooksu ValueErroru isinstanceu collectionsuCallableuappenduhasattruextend(uselfueventuhook((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu register_hookžs uRequestHooksMixin.register_hookc Cs9y|j|j|ƒdSWntk r4dSYnXdS(uiDeregister a previously registered hook. Returns True if the hook existed, False if not. NTF(uhooksuremoveuTrueu ValueErroruFalse(uselfueventuhook((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuderegister_hook©s  u!RequestHooksMixin.deregister_hookN(u__name__u __module__u __qualname__u register_hookuderegister_hook(u __locals__((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuRequestHooksMixins uRequestHooksMixinc BsY|EeZdZdZddddddddddd„ Zdd„Zdd„ZdS( uRequestuA user-created :class:`Request ` object. Used to prepare a :class:`PreparedRequest `, which is sent to the server. :param method: HTTP method to use. :param url: URL to send. :param headers: dictionary of headers to send. :param files: dictionary of {filename: fileobject} files to multipart upload. :param data: the body to attach the request. If a dictionary is provided, form-encoding will take place. :param params: dictionary of URL parameters to append to the URL. :param auth: Auth handler or (user, pass) tuple. :param cookies: dictionary or CookieJar of cookies to attach to this request. :param hooks: dictionary of callback hooks, for internal usage. Usage:: >>> import requests >>> req = requests.Request('GET', 'http://httpbin.org/get') >>> req.prepare() c Cs |dkrgn|}|dkr*gn|}|dkrBin|}|dkrZin|}| dkrrin| } tƒ|_x6t| jƒƒD]"\} } |jd| d| ƒq—W||_||_||_||_ ||_ ||_ ||_ ||_ dS(Nueventuhook(uNoneu default_hooksuhooksulistuitemsu register_hookumethoduurluheadersufilesudatauparamsuauthucookies( uselfumethoduurluheadersufilesudatauparamsuauthucookiesuhooksukuv((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__init__Ìs         uRequest.__init__cCs d|jS(Nu(umethod(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__repr__ësuRequest.__repr__cCshtƒ}|jd|jd|jd|jd|jd|jd|jd|jd|j d |j ƒ |S( uXConstructs a :class:`PreparedRequest ` for transmission and returns it.umethoduurluheadersufilesudatauparamsuauthucookiesuhooks( uPreparedRequestuprepareumethoduurluheadersufilesudatauparamsuauthucookiesuhooks(uselfup((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuprepareîs           uRequest.prepareN(u__name__u __module__u __qualname__u__doc__uNoneu__init__u__repr__uprepare(u __locals__((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuRequestµs uRequestc BsÈ|EeZdZdZdd„Zddddddddddd„ Zdd„Zdd „Zd d „Z d d „Z dd„Z dd„Z dd„Z ddd„Zdd„Zdd„ZdS(uPreparedRequestuÇThe fully mutable :class:`PreparedRequest ` object, containing the exact bytes that will be sent to the server. Generated from either a :class:`Request ` object or manually. Usage:: >>> import requests >>> req = requests.Request('GET', 'http://httpbin.org/get') >>> r = req.prepare() >>> s = requests.Session() >>> s.send(r) cCs=d|_d|_d|_d|_d|_tƒ|_dS(N(uNoneumethoduurluheadersu_cookiesubodyu default_hooksuhooks(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__init__s      uPreparedRequest.__init__c Csh|j|ƒ|j||ƒ|j|ƒ|j|ƒ|j||ƒ|j||ƒ|j| ƒdS(u6Prepares the entire request with the given parameters.N(uprepare_methodu prepare_urluprepare_headersuprepare_cookiesu prepare_bodyu prepare_authu prepare_hooks( uselfumethoduurluheadersufilesudatauparamsuauthucookiesuhooks((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuprepare!s   uPreparedRequest.preparecCs d|jS(Nu(umethod(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__repr__1suPreparedRequest.__repr__cCsatƒ}|j|_|j|_|jjƒ|_|jjƒ|_|j|_|j|_|S(N(uPreparedRequestumethoduurluheadersucopyu_cookiesubodyuhooks(uselfup((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyucopy4s     uPreparedRequest.copycCs1||_|jdk r-|jjƒ|_ndS(uPrepares the given HTTP method.N(umethoduNoneuupper(uselfumethod((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuprepare_method>s uPreparedRequest.prepare_methodc Csqyt|ƒ}Wn/tk r0t|ƒ}Yntk rAYnXd|krq|jƒjdƒ rq||_dSt|ƒ\}}}}}}} |s°tdj |ƒƒ‚n|sÉt d|ƒ‚ny|j dƒj dƒ}Wnt k rt dƒ‚YnX|pd } | r%| d 7} n| |7} |rL| dt|ƒ7} n|s[d }ntr t|tƒr‚|j dƒ}nt| tƒr£| j dƒ} nt|tƒrÄ|j dƒ}nt|tƒrå|j dƒ}nt| tƒr | j dƒ} q n|j|ƒ} | r@|r7d || f}q@| }ntt|| |d|| gƒƒ}||_dS( uPrepares the given HTTP URL.u:uhttpNuDInvalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?u Invalid URL %r: No host supplieduidnauutf-8uURL has an invalid label.uu@u/u%s&%s(uunicodeu NameErrorustruUnicodeDecodeErroruloweru startswithuurlu parse_urlu MissingSchemauformatu InvalidURLuencodeudecodeu UnicodeErroruis_py2u isinstanceu_encode_paramsu requote_uriu urlunparseuNone( uselfuurluparamsuschemeuauthuhostuportupathuqueryufragmentunetlocu enc_params((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu prepare_urlDsZ  " !       $uPreparedRequest.prepare_urlcCs;|r+tdd„|jƒDƒƒ|_n tƒ|_dS(u Prepares the given HTTP headers.css'|]\}}t|ƒ|fVqdS(N(uto_native_string(u.0unameuvalue((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu Šsu2PreparedRequest.prepare_headers..N(uCaseInsensitiveDictuitemsuheaders(uselfuheaders((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuprepare_headers†s%uPreparedRequest.prepare_headerscCs~d }d }d }tt|dƒt|ttttfƒ gƒ}yt|ƒ}Wn!t t t fk rvd }YnX|rÊ|}|r˜t dƒ‚n|d k rºt |ƒ|jd` object, which contains a server's response to an HTTP request. u_contentu status_codeuheadersuurluhistoryuencodingureasonucookiesuelapsedurequestcsŒtt|ƒjƒd|_d|_d|_tƒ|_ d|_ d|_ d|_ g|_ d|_tiƒ|_tjdƒ|_dS(NiF(usuperuResponseu__init__uFalseu_contentu_content_consumeduNoneu status_codeuCaseInsensitiveDictuheadersurawuurluencodinguhistoryureasonucookiejar_from_dictucookiesudatetimeu timedeltauelapsed(uself(u __class__(u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__init__s         uResponse.__init__cs3ˆjsˆjnt‡fdd†ˆjDƒƒS(Nc3s'|]}|tˆ|dƒfVqdS(N(ugetattruNone(u.0uattr(uself(u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu 6su(Response.__getstate__..(u_content_consumeducontentudictu __attrs__(uself((uselfu4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu __getstate__/s   uResponse.__getstate__cCsQx*|jƒD]\}}t|||ƒq Wt|ddƒt|ddƒdS(Nu_content_consumedurawT(uitemsusetattruTrueuNone(uselfustateunameuvalue((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu __setstate__:suResponse.__setstate__cCs d|jS(Nu(u status_code(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__repr__BsuResponse.__repr__cCs|jS(u,Returns true if :attr:`status_code` is 'OK'.(uok(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__bool__EsuResponse.__bool__cCs|jS(u,Returns true if :attr:`status_code` is 'OK'.(uok(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu __nonzero__IsuResponse.__nonzero__cCs |jdƒS(u,Allows you to use a response as an iterator.i€(u iter_content(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu__iter__MsuResponse.__iter__c Cs+y|jƒWntk r&dSYnXdS(NFT(uraise_for_statusuRequestExceptionuFalseuTrue(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuokQs   u Response.okcCsd|jko|jtkS(ušTrue if this Response is a well-formed HTTP redirect that could have been processed automatically (by :meth:`Session.resolve_redirects`). ulocation(uheadersu status_codeuREDIRECT_STATI(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu is_redirectYsuResponse.is_redirectcCstj|jƒdS(u6The apparent encoding, provided by the chardet libraryuencoding(uchardetudetectucontent(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuapparent_encoding`suResponse.apparent_encodingicsa‡‡fdd†}tˆjˆƒ}|ƒ}ˆjr?|n|}|r]t|ˆƒ}n|S(uÑIterates over the response data. When stream=True is set on the request, this avoids reading the content at once into memory for large responses. The chunk size is the number of bytes it should read into memory. This is not necessarily the length of each item returned as decoding can take place. If decode_unicode is True, content will be decoded using the best available encoding based on the response. c3sÝy”y,x%ˆjjˆddƒD] }|VqWWnatk rb}zt|ƒ‚WYdd}~Xn1tk r’}zt|ƒ‚WYdd}~XnXWn9tk rÏx$ˆjjˆƒ}|sÃPn|Vq§YnXdˆ_ dS(Nudecode_contentT( urawustreamuTrueuIncompleteReaduChunkedEncodingErroru DecodeErroruContentDecodingErroruAttributeErrorureadu_content_consumed(uchunkue(u chunk_sizeuself(u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyugenerateos #  u'Response.iter_content..generate(u iter_slicesu_contentu_content_consumedustream_decode_response_unicode(uselfu chunk_sizeudecode_unicodeugenerateu reused_chunksu stream_chunksuchunks((u chunk_sizeuselfu4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu iter_contentes  uResponse.iter_contentccs¿d}xž|jd|d|ƒD]„}|dk r>||}n|jƒ}|r‡|dr‡|r‡|dd|dkr‡|jƒ}nd}x|D] }|Vq”WqW|dk r»|VndS( u¿Iterates over the response data, one line at a time. When stream=True is set on the request, this avoids reading the content at once into memory for large responses. u chunk_sizeudecode_unicodeiNiÿÿÿÿiÿÿÿÿiÿÿÿÿiÿÿÿÿ(uNoneu iter_contentu splitlinesupop(uselfu chunk_sizeudecode_unicodeupendinguchunkulinesuline((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyu iter_liness   .   uResponse.iter_linesc Csž|jdkrŽy^|jr*tdƒ‚n|jdkrEd|_n'tƒj|jt ƒƒpftƒ|_WqŽt k rŠd|_YqŽXnd|_|jS(u"Content of the response, in bytes.u2The content for this response was already consumediFNT( u_contentuFalseu_content_consumedu RuntimeErroru status_codeuNoneubytesujoinu iter_contentuCONTENT_CHUNK_SIZEuAttributeErroruTrue(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyucontent¨s   +  uResponse.contentc Csd}|j}|js"tdƒS|jdkr=|j}nyt|j|ddƒ}Wn-ttfk rˆt|jddƒ}YnX|S(uÀContent of the response, in unicode. If Response.encoding is None, encoding will be guessed using ``chardet``. The encoding of the response content is determined based solely on HTTP headers, following RFC 2616 to the letter. If you can take advantage of non-HTTP knowledge to make a better guess at the encoding, you should set ``r.encoding`` appropriately before accessing this property. uuerrorsureplaceN(uNoneuencodingucontentustruapparent_encodingu LookupErroru TypeError(uselfucontentuencoding((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyutextÀs    u Response.textc Ksˆ|j rut|jƒdkrut|jƒ}|dk ruy tj|jj|ƒ|SWqrtk rnYqrXquntj|j |S(uŠReturns the json-encoded content of a response, if any. :param \*\*kwargs: Optional arguments that ``json.loads`` takes. iN( uencodingulenucontentuguess_json_utfuNoneujsonuloadsudecodeuUnicodeDecodeErrorutext(uselfukwargsuencoding((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyujsonæs    u Response.jsoncCsj|jjdƒ}i}|rft|ƒ}x9|D].}|jdƒpR|jdƒ}|||d|j|jf}n8d|jkoXdknrvd|j|jf}n|r‘t|d|ƒ‚ndS( u2Raises stored :class:`HTTPError`, if one occurred.uiiôu%s Client Error: %siXu%s Server Error: %suresponseN(u status_codeureasonu HTTPError(uselfuhttp_error_msg((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuraise_for_statussuResponse.raise_for_statuscCs |jjƒS(uØReleases the connection back to the pool. Once this method has been called the underlying ``raw`` object must not be accessed again. *Note: Should not normally need to be called explicitly.* (urawu release_conn(uself((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuclosesuResponse.closeFN(u__name__u __module__u __qualname__u__doc__u __attrs__u__init__u __getstate__u __setstate__u__repr__u__bool__u __nonzero__u__iter__upropertyuoku is_redirectuapparent_encodinguFalseu iter_contentuITER_CHUNK_SIZEuNoneu iter_linesucontentutextujsonulinksuraise_for_statusuclose(u __locals__((u __class__u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyuResponseõs: (     *&  uResponsei((Gu__doc__u collectionsudatetimeuiouBytesIOuUnsupportedOperationuhooksu default_hooksu structuresuCaseInsensitiveDictuauthu HTTPBasicAuthucookiesucookiejar_from_dictuget_cookie_headerupackages.urllib3.fieldsu RequestFieldupackages.urllib3.filepostuencode_multipart_formdataupackages.urllib3.utilu parse_urlupackages.urllib3.exceptionsu DecodeErroru exceptionsu HTTPErroruRequestExceptionu MissingSchemau InvalidURLuChunkedEncodingErroruContentDecodingErroruutilsuguess_filenameuget_auth_from_urlu requote_uriustream_decode_response_unicodeuto_key_val_listuparse_header_linksu iter_slicesuguess_json_utfu super_lenuto_native_stringucompatu cookielibu urlunparseuurlsplitu urlencodeustrubytesuStringIOuis_py2uchardetujsonu builtin_stru basestringuIncompleteReadu status_codesucodesumovedufounduotherutemporary_moveduREDIRECT_STATIuDEFAULT_REDIRECT_LIMITuCONTENT_CHUNK_SIZEuITER_CHUNK_SIZEuobjectuRequestEncodingMixinuRequestHooksMixinuRequestuPreparedRequestuResponse(((u4/tmp/pip-zej_zi-build/pip/_vendor/requests/models.pyus6  .FX mJö