Current File : //lib/python2.7/site-packages/requests/models.pyo
�
YЅ_c@s`dZddlZddlZddlmZmZddlmZddlm	Z	ddl
mZddlm
Z
mZdd	lmZdd
lmZddlmZddlmZmZmZmZdd
lmZmZmZmZmZm Z m!Z!ddl"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+m,Z,ddl-m.Z.m/Z/m0Z0m1Z1m2Z2m3Z3m4Z4m5Z5m6Z6m7Z7m8Z8m9Z9ddl:m;Z;e;j<e;j=e;j>e;j?e;j@fZAdZBddZCdZDe7jEZFdeGfd��YZHdeGfd��YZIdeIfd��YZJdeHeIfd��YZKdeGfd��YZLdS(s`
requests.models
~~~~~~~~~~~~~~~

This module contains the primary objects that power Requests.
i����N(tBytesIOtUnsupportedOperationi(t
default_hooks(tCaseInsensitiveDict(t
HTTPBasicAuth(tcookiejar_from_dicttget_cookie_header(tRequestField(tencode_multipart_formdata(t	parse_url(tDecodeErrortReadTimeoutErrort
ProtocolErrortLocationParseError(t	HTTPErrort
MissingSchemat
InvalidURLtChunkedEncodingErrortContentDecodingErrortConnectionErrortStreamConsumedError(
tguess_filenametget_auth_from_urltrequote_uritstream_decode_response_unicodetto_key_val_listtparse_header_linkstiter_slicestguess_json_utft	super_lentto_native_string(t	cookielibt
urlunparseturlsplitt	urlencodetstrtbytestStringIOtis_py2tchardettjsontbuiltin_strt
basestring(tcodesii
iitRequestEncodingMixincBs5eZed��Zed��Zed��ZRS(cCssg}t|j�}|j}|s-d}n|j|�|j}|rf|jd�|j|�ndj|�S(sBuild the path URL to use.t/t?t(R!turltpathtappendtquerytjoin(tselfR0tpR1R3((s3/usr/lib/python2.7/site-packages/requests/models.pytpath_url5s		
	
cCst|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	|dt
�S|SdS(s�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.
        treadt__iter__sutf-8tdoseqN(t
isinstanceR#R$thasattrRR*tNoneR2tencodeR"tTrue(tdatatresulttktvstv((s3/usr/lib/python2.7/site-packages/requests/models.pyt_encode_paramsJs 	
!3c
Cs]|std��nt|t�r3td��ng}t|pEi�}t|pWi�}x�|D]�\}}t|t�s�t|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|ttf�r�t
|�dkr�|\}
}q�t
|�dkr�|\}
}}q�|\}
}}}	nt|�p�|}
|}t|tttf�r�|}n|j�}td|d|d	|
d
|	�}
|
jd|�|j|
�q3Wt|�\}}||fS(
sBuild 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.

        sFiles must be provided.sData must not be a string.R9sutf-8iitnameR@tfilenametheaderstcontent_typeN(t
ValueErrorR;R*RR<R=R$R#R2tdecodeR>ttupletlisttlenRt	bytearrayR8Rtmake_multipartR(tfilesR@t
new_fieldstfieldstfieldtvalRDRBtfttfhtfntfptfdatatrftbodyRI((s3/usr/lib/python2.7/site-packages/requests/models.pyt
_encode_filesesJ	
!3	(t__name__t
__module__tpropertyR7tstaticmethodRER](((s3/usr/lib/python2.7/site-packages/requests/models.pyR,4stRequestHooksMixincBseZd�Zd�ZRS(cCs||jkr"td|��nt|tj�rK|j|j|�n0t|d�r{|j|jd�|D��ndS(sProperly register a hook.s1Unsupported event specified, with event name "%s"R9css'|]}t|tj�r|VqdS(N(R;tcollectionstCallable(t.0th((s3/usr/lib/python2.7/site-packages/requests/models.pys	<genexpr>�sN(thooksRJR;RcRdR2R<textend(R5teventthook((s3/usr/lib/python2.7/site-packages/requests/models.pyt
register_hook�scCs5y|j|j|�tSWntk
r0tSXdS(siDeregister a previously registered hook.
        Returns True if the hook existed, False if not.
        N(RgtremoveR?RJtFalse(R5RiRj((s3/usr/lib/python2.7/site-packages/requests/models.pytderegister_hook�s

(R^R_RkRn(((s3/usr/lib/python2.7/site-packages/requests/models.pyRb�s	tRequestcBsGeZdZddddddddddd�
Zd�Zd�ZRS(s�A user-created :class:`Request <Request>` object.

    Used to prepare a :class:`PreparedRequest <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 to the request. If a dictionary is provided, form-encoding will take place.
    :param json: json for the body to attach to the request (if data is not specified).
    :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()
      <PreparedRequest [GET]>

    c
Cs|dkrgn|}|dkr*gn|}|dkrBin|}|dkrZin|}|	dkrrin|	}	t�|_x6t|	j��D]"\}}|jd|d|�q�W||_||_||_||_	||_
|
|_||_||_
||_dS(NRiRj(R=RRgRMtitemsRktmethodR0RHRQR@R(tparamstauthtcookies(
R5RqR0RHRQR@RrRsRtRgR(RBRD((s3/usr/lib/python2.7/site-packages/requests/models.pyt__init__�s"
								cCsd|jS(Ns<Request [%s]>(Rq(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyt__repr__�scCsqt�}|jd|jd|jd|jd|jd|jd|jd|jd|j	d	|j
d
|j�
|S(sXConstructs a :class:`PreparedRequest <PreparedRequest>` for transmission and returns it.RqR0RHRQR@R(RrRsRtRg(tPreparedRequesttprepareRqR0RHRQR@R(RrRsRtRg(R5R6((s3/usr/lib/python2.7/site-packages/requests/models.pyRx�s											
N(R^R_t__doc__R=RuRvRx(((s3/usr/lib/python2.7/site-packages/requests/models.pyRo�s	RwcBs�eZdZd�Zddddddddddd�
Zd�Zd�Zd�Zd�Z	d�Z
dd�Zd	�Zd
d�Z
d�Zd
�ZRS(s�The fully mutable :class:`PreparedRequest <PreparedRequest>` object,
    containing the exact bytes that will be sent to the server.

    Generated from either a :class:`Request <Request>` object or manually.

    Usage::

      >>> import requests
      >>> req = requests.Request('GET', 'http://httpbin.org/get')
      >>> r = req.prepare()
      <PreparedRequest [GET]>

      >>> s = requests.Session()
      >>> s.send(r)
      <Response [200]>

    cCs=d|_d|_d|_d|_d|_t�|_dS(N(R=RqR0RHt_cookiesR\RRg(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyRus					cCsk|j|�|j||�|j|�|j|�|j|||
�|j||�|j|	�dS(s6Prepares the entire request with the given parameters.N(tprepare_methodtprepare_urltprepare_headerstprepare_cookiestprepare_bodytprepare_autht
prepare_hooks(R5RqR0RHRQR@RrRsRtRgR(((s3/usr/lib/python2.7/site-packages/requests/models.pyRx*s


cCsd|jS(Ns<PreparedRequest [%s]>(Rq(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyRv;scCs�t�}|j|_|j|_|jdk	r?|jj�nd|_|jdk	rf|jj�nd|_|j|_|j|_|S(N(	RwRqR0RHR=tcopyRzR\Rg(R5R6((s3/usr/lib/python2.7/site-packages/requests/models.pyR�>s	''cCs1||_|jdk	r-|jj�|_ndS(sPrepares the given HTTP method.N(RqR=tupper(R5Rq((s3/usr/lib/python2.7/site-packages/requests/models.pyR{Hs	c

Cs�t|t�r!|jd�}ntr3t|�n	t|�}d|krn|j�jd�rn||_dSy%t	|�\}}}}}}}	Wn"t
k
r�}
t|
j��nX|s�t
dj|���n|s�td|��ny|jd�jd�}Wntk
r*td	��nX|p4d
}|rJ|d7}n||7}|rq|dt|�7}n|s�d}ntr.t|t�r�|jd�}nt|t�r�|jd�}nt|t�r�|jd�}nt|t�r
|jd�}nt|	t�r.|	jd�}	q.n|j|�}|re|r\d
||f}qe|}ntt|||d||	g��}||_dS(sPrepares the given HTTP URL.tutf8t:thttpNsDInvalid URL {0!r}: No schema supplied. Perhaps you meant http://{0}?s Invalid URL %r: No host suppliedtidnasutf-8sURL has an invalid label.R/t@R-s%s&%s(R;R$RKR&tunicodeR#tlowert
startswithR0R	R
RtargsRtformatR>tUnicodeErrorRERR R=(
R5R0RrtschemeRsthosttportR1R3tfragmenttetnetloct
enc_params((s3/usr/lib/python2.7/site-packages/requests/models.pyR|NsZ"	%	


		$cCs8|r(td�|j�D��|_nt�|_dS(s Prepares the given HTTP headers.css'|]\}}t|�|fVqdS(N(R(ReRFtvalue((s3/usr/lib/python2.7/site-packages/requests/models.pys	<genexpr>�sN(RRpRH(R5RH((s3/usr/lib/python2.7/site-packages/requests/models.pyR}�s"cCs�d}d}d}|dk	r3d}t|�}ntt|d�t|ttttf�g�}yt	|�}Wn t
ttfk
r�d}nX|r�|}|r�t
d��n|dk	r�t|�|jd<q�d|jd<n�|r|j||�\}}nQ|r\|dkr\|j|�}t|t�sJt|d�rSd}q\d}n|j|�|r�d	|jkr�||jd
<n||_dS(s"Prepares the given HTTP body data.sapplication/jsonR9s1Streamed bodies and files are mutually exclusive.sContent-LengthtchunkedsTransfer-EncodingR8s!application/x-www-form-urlencodedscontent-typesContent-TypeN(R=t
json_dumpstallR<R;R*RMRLtdictRt	TypeErrortAttributeErrorRtNotImplementedErrorR)RHR]REtprepare_content_lengthR\(R5R@RQR(R\RItlengtht	is_stream((s3/usr/lib/python2.7/site-packages/requests/models.pyR�s>"
		
cCs�t|d�rZt|d�rZ|jdd�t|j��|jd<|jdd�nn|dk	r�t|�}|r�t|�|jd<q�n7|jd	kr�|jjd�dkr�d|jd<ndS(
NtseekttelliisContent-LengthtGETtHEADt0(R�R�(	R<R�R)R�RHR=RRqtget(R5R\tl((s3/usr/lib/python2.7/site-packages/requests/models.pyR��s'R/cCs�|dkr6t|j�}t|�r-|nd}n|r�t|t�rlt|�dkrlt|�}n||�}|jj	|j�|j
|j�ndS(s"Prepares the given HTTP auth data.iN(R=RR0tanyR;RLRNRt__dict__tupdateR�R\(R5RsR0turl_authtr((s3/usr/lib/python2.7/site-packages/requests/models.pyR��s!cCs_t|tj�r||_nt|�|_t|j|�}|dk	r[||jd<ndS(s$Prepares the given HTTP cookie data.tCookieN(R;Rt	CookieJarRzRRR=RH(R5Rtt
cookie_header((s3/usr/lib/python2.7/site-packages/requests/models.pyR~�scCs)x"|D]}|j|||�qWdS(sPrepares the given hooks.N(Rk(R5RgRi((s3/usr/lib/python2.7/site-packages/requests/models.pyR�s
N(R^R_RyRuR=RxRvR�R{R|R}RR�R�R~R�(((s3/usr/lib/python2.7/site-packages/requests/models.pyRws			
		H	7		tResponsec
BseZdZddddddddd	d
g
Zd�Zd�Zd
�Zd�Zd�Zd�Z	d�Z
ed��Zed��Z
ed��Zed��Zded�Zeddd�Zed��Zed��Zd�Zed��Zd�Zd�ZRS( shThe :class:`Response <Response>` object, which contains a
    server's response to an HTTP request.
    t_contenttstatus_codeRHR0thistorytencodingtreasonRttelapsedtrequestcCs�tt|�j�t|_t|_d|_t�|_	d|_
d|_d|_g|_
d|_ti�|_tjd�|_d|_dS(Ni(tsuperR�RuRmR�t_content_consumedR=R�RRHtrawR0R�R�R�RRttdatetimet	timedeltaR�R�(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyRus								cs0�js�jnt�fd��jD��S(Nc3s'|]}|t�|d�fVqdS(N(tgetattrR=(Retattr(R5(s3/usr/lib/python2.7/site-packages/requests/models.pys	<genexpr>Ns(R�tcontentR�t	__attrs__(R5((R5s3/usr/lib/python2.7/site-packages/requests/models.pyt__getstate__Gs
	
cCsQx*|j�D]\}}t|||�q
Wt|dt�t|dd�dS(NR�R�(RptsetattrR?R=(R5tstateRFR�((s3/usr/lib/python2.7/site-packages/requests/models.pyt__setstate__RscCsd|jS(Ns<Response [%s]>(R�(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyRvZscCs|jS(s,Returns true if :attr:`status_code` is 'OK'.(tok(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyt__bool__]scCs|jS(s,Returns true if :attr:`status_code` is 'OK'.(R�(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyt__nonzero__ascCs
|jd�S(s,Allows you to use a response as an iterator.i�(titer_content(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyR9escCs'y|j�Wntk
r"tSXtS(N(traise_for_statusRRmR?(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyR�is

cCsd|jko|jtkS(s�True if this Response is a well-formed HTTP redirect that could have
        been processed automatically (by :meth:`Session.resolve_redirects`).
        tlocation(RHR�tREDIRECT_STATI(R5((s3/usr/lib/python2.7/site-packages/requests/models.pytis_redirectqscCs(d|jko'|jtjtjfkS(s?True if this Response one of the permanant versions of redirectR�(RHR�R+tmoved_permanentlytpermanent_redirect(R5((s3/usr/lib/python2.7/site-packages/requests/models.pytis_permanent_redirectxscCstj|j�dS(s6The apparent encoding, provided by the chardet libraryR�(R'tdetectR�(R5((s3/usr/lib/python2.7/site-packages/requests/models.pytapparent_encoding}sics���fd�}�jr9t�jt�r9t��nt�j��}|�}�jrc|n|}|r�t|��}n|S(s�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�dt�D]}|VqWWn[tk
rP}t|��n=tk
rn}t|��ntk
r�}t|��nXWn?t	k
r�x/tr��jj
��}|s�Pn|Vq�WnXt�_dS(Ntdecode_content(R�tstreamR?RRR
RRRR�R8R�(tchunkR�(t
chunk_sizeR5(s3/usr/lib/python2.7/site-packages/requests/models.pytgenerate�s"

	
(R�R;R�tboolRRR(R5R�tdecode_unicodeR�t
reused_chunkst
stream_chunkstchunks((R�R5s3/usr/lib/python2.7/site-packages/requests/models.pyR��s
	ccs�d}x�|jd|d|�D]�}|dk	r>||}n|rV|j|�}n|j�}|r�|dr�|r�|dd|dkr�|j�}nd}x|D]}|Vq�WqW|dk	r�|VndS(s�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.

        .. note:: This method is not reentrant safe.
        R�R�i����N(R=R�tsplitt
splitlinestpop(R5R�R�t	delimitertpendingR�tlinestline((s3/usr/lib/python2.7/site-packages/requests/models.pyt
iter_lines�s
.

cCs�|jtkr�y^|jr*td��n|jdkrEd|_n't�j|jt	��pft�|_Wq�t
k
r�d|_q�Xnt|_|jS(s"Content of the response, in bytes.s2The content for this response was already consumediN(R�RmR�tRuntimeErrorR�R=R$R4R�tCONTENT_CHUNK_SIZER�R?(R5((s3/usr/lib/python2.7/site-packages/requests/models.pyR��s	+
	cCs�d}|j}|js"td�S|jdkr=|j}nyt|j|dd�}Wn,ttfk
r�t|jdd�}nX|S(s�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.
        R/terrorstreplaceN(R=R�R�R#R�tLookupErrorR�(R5R�R�((s3/usr/lib/python2.7/site-packages/requests/models.pyttext�s		
cKs�|jrtt|j�dkrtt|j�}|dk	rty tj|jj|�|�SWqqtk
rmqqXqtntj|j	|�S(s�Returns the json-encoded content of a response, if any.

        :param \*\*kwargs: Optional arguments that ``json.loads`` takes.
        iN(
R�RNR�RR=R(tloadsRKtUnicodeDecodeErrorR�(R5tkwargsR�((s3/usr/lib/python2.7/site-packages/requests/models.pyR(
s 

cCsj|jjd�}i}|rft|�}x9|D].}|jd�pR|jd�}|||<q1Wn|S(s8Returns the parsed header links of the response, if any.tlinktrelR0(RHR�R(R5theaderR�tlinksR�tkey((s3/usr/lib/python2.7/site-packages/requests/models.pyR�$s
cCs�d}d|jko dknr>d|j|jf}n8d|jkoXdknrvd|j|jf}n|r�t|d|��ndS(	s2Raises stored :class:`HTTPError`, if one occurred.R/i�i�s%s Client Error: %siXs%s Server Error: %stresponseN(R�R�R(R5thttp_error_msg((s3/usr/lib/python2.7/site-packages/requests/models.pyR�6scCs
|jj�S(s�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.*
        (R�trelease_conn(R5((s3/usr/lib/python2.7/site-packages/requests/models.pytcloseDsN(R^R_RyR�RuR�R�RvR�R�R9R`R�R�R�R�RmR�tITER_CHUNK_SIZER=R�R�R�R(R�R�R�(((s3/usr/lib/python2.7/site-packages/requests/models.pyR�	s<		,						.&		(MRyRcR�tioRRRgRt
structuresRRsRRtRRturllib3.fieldsRturllib3.filepostRturllib3.utilR	turllib3.exceptionsR
RRR
t
exceptionsRRRRRRRtutilsRRRRRRRRRRtcompatRR R!R"R#R$R%R&R'R(R)R*tstatus_codesR+tmovedtfoundtotherttemporary_redirectR�R�tDEFAULT_REDIRECT_LIMITR�R�tdumpsR�tobjectR,RbRoRwR�(((s3/usr/lib/python2.7/site-packages/requests/models.pyt<module>s<"4FR
	nN�