Current File : //lib/python2.7/site-packages/urllib3/fields.pyc
�
v�Sc@sWddlZddlZddlmZdd�Zd�Zdefd��YZdS(	i����Ni(tsixsapplication/octet-streamcCs!|rtj|�dp|S|S(s�
    Guess the "Content-Type" of a file.

    :param filename:
        The filename to guess the "Content-Type" of using :mod:`mimetypes`.
    :param default:
        If no "Content-Type" can be guessed, default to `default`.
    i(t	mimetypest
guess_type(tfilenametdefault((s2/usr/lib/python2.7/site-packages/urllib3/fields.pytguess_content_types	cs�t�fd�dD��sXd|�f}y|jd�Wntk
rPqXX|Sntjss�jd��ntjj�d��d|�f��S(s�
    Helper function to format and quote a single header parameter.

    Particularly useful for header parameters which might contain
    non-ASCII values, like file names. This follows RFC 2231, as
    suggested by RFC 2388 Section 4.4.

    :param name:
        The name of the parameter, a string expected to be ASCII only.
    :param value:
        The value of the parameter, provided as a unicode string.
    c3s|]}|�kVqdS(N((t.0tch(tvalue(s2/usr/lib/python2.7/site-packages/urllib3/fields.pys	<genexpr>"ss"\
s%s="%s"tasciisutf-8s%s*=%s(tanytencodetUnicodeEncodeErrorRtPY3temailtutilstencode_rfc2231(tnameRtresult((Rs2/usr/lib/python2.7/site-packages/urllib3/fields.pytformat_header_params

	tRequestFieldcBsYeZdZddd�Zed��Zd�Zd�Zd�Z	dddd�Z
RS(sK
    A data container for request body parameters.

    :param name:
        The name of this request field.
    :param data:
        The data/value body.
    :param filename:
        An optional filename of the request field.
    :param headers:
        An optional dict-like object of headers to initially use for the field.
    cCs@||_||_||_i|_|r<t|�|_ndS(N(t_namet	_filenametdatatheaderstdict(tselfRRRR((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyt__init__>s				cCs�t|t�rNt|�dkr3|\}}}q`|\}}t|�}nd}d}|}|||d|�}|jd|�|S(s�
        A :class:`~urllib3.fields.RequestField` factory from old-style tuple parameters.

        Supports constructing :class:`~urllib3.fields.RequestField` from
        parameter of key/value strings AND key/filetuple. A filetuple is a
        (filename, data, MIME type) tuple where the MIME type is optional.
        For example::

            'foo': 'bar',
            'fakefile': ('foofile.txt', 'contents of foofile'),
            'realfile': ('barfile.txt', open('realfile').read()),
            'typedfile': ('bazfile.bin', open('bazfile').read(), 'image/jpeg'),
            'nonamefile': 'contents of nonamefile field',

        Field names and filenames must be unicode.
        iRtcontent_typeN(t
isinstancettupletlenRtNonetmake_multipart(tclst	fieldnameRRRRt
request_param((s2/usr/lib/python2.7/site-packages/urllib3/fields.pytfrom_tuplesFscCs
t||�S(s
        Overridable helper function to format a single header parameter.

        :param name:
            The name of the parameter, a string expected to be ASCII only.
        :param value:
            The value of the parameter, provided as a unicode string.
        (R(RRR((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyt_render_parths	cCspg}|}t|t�r*|j�}nx6|D].\}}|r1|j|j||��q1q1Wdj|�S(sO
        Helper function to format and quote a single header.

        Useful for single headers that are composed of multiple items. E.g.,
        'Content-Disposition' fields.

        :param header_parts:
            A sequence of (k, v) typles or a :class:`dict` of (k, v) to format
            as `k1="v1"; k2="v2"; ...`.
        s; (RRtitemstappendR&tjoin(Rtheader_partstpartstiterableRR((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyt
_render_partsss cCs�g}dddg}xD|D]<}|jj|t�r|jd||j|f�qqWxL|jj�D];\}}||krl|r�|jd||f�q�qlqlW|jd�dj|�S(s=
        Renders the headers for this request field.
        sContent-DispositionsContent-TypesContent-Locations%s: %ss
(RtgettFalseR(R'R)(Rtlinest	sort_keystsort_keytheader_nametheader_value((s2/usr/lib/python2.7/site-packages/urllib3/fields.pytrender_headers�s
%!
c
Cst|p	d|jd<|jdcdjd|jd|jfd|jff�g�7<||jd<||jd<d	S(
s|
        Makes this request field into a multipart request field.

        This method overrides "Content-Disposition", "Content-Type" and
        "Content-Location" headers to the request parameter.

        :param content_type:
            The 'Content-Type' of the request body.
        :param content_location:
            The 'Content-Location' of the request body.

        s	form-datasContent-Dispositions; tRRsContent-TypesContent-LocationN(RR)R-RR(Rtcontent_dispositionRtcontent_location((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyR!�s	'
N(t__name__t
__module__t__doc__R RtclassmethodR%R&R-R5R!(((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyR1s"			(	temail.utilsRRtpackagesRRRtobjectR(((s2/usr/lib/python2.7/site-packages/urllib3/fields.pyt<module>s