Ë

����{£éf[*��ã������������������óö���—�d�dl�mZ�d�dlZd�dlZd�dlZej������������������eef���Z	ej������������������e	ej������������������ee	f���ej������������������ee	ef���f���Z	�d
	�	�	�	�	�dd„Zdd„Z
dd„Zdd„Zdd„Z�G�d„�d	«������Zy)
é����)ÚannotationsNc����������������óB���—�|�rt��������j������������������|�«������d���xs�|S�|S�)zæ
    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`.
    r���)Ú	mimetypesÚ
guess_type)ÚfilenameÚdefaults���  úW/var/lib/jenkins/workspace/mettalog/venv/lib/python3.12/site-packages/urllib3/fields.pyÚguess_content_typer
������s'���€�ñ�Ü×#Ñ# HÓ-¨aÑ0Ò;°GÐ;Ø€Nó����c����������������óZ��‡—�ddl�}|j������������������dt��������d¬«�������t��������‰t��������«������r‰j������������������d«������Št
��������ˆfd„dD�«�������«������s|�›�d	‰›�d
}	�|j������������������d«�������|S�t��������j������������������j������������������‰d«������Š|�›�d‰›�Š‰S�#�t��������t��������f$�r�Y�Œ:w�xY�w)
a´��
    Helper function to format and quote a single header parameter using the
    strategy defined in RFC 2231.

    Particularly useful for header parameters which might contain
    non-ASCII values, like file names. This follows
    `RFC 2388 Section 4.4 <https://tools.ietf.org/html/rfc2388#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 ``bytes`` or `str``.
    :returns:
        An RFC-2231-formatted unicode string.

    .. deprecated:: 2.0.0
        Will be removed in urllib3 v2.1.0. This is not valid for
        ``multipart/form-data`` header parameters.
    r���Nz'format_header_param_rfc2231' is deprecated and will be removed in urllib3 v2.1.0. This is not valid for multipart/form-data header parameters.é���©Ú
stacklevelúutf-8c��������������3��ó&���•K��—�|�]��}|‰v�–—�Œ
�y�­w©N©�)Ú.0ÚchÚvalues���  €r	���ú	<genexpr>z.format_header_param_rfc2231.<locals>.<genexpr>@���s���øè�ø€�Ò/˜rˆrUŒ{Ñ/ùs���ƒz"\
ú="ú"Úasciiz*=)
ÚwarningsÚwarnÚDeprecationWarningÚ
isinstanceÚbytesÚdecodeÚanyÚencodeÚUnicodeEncodeErrorÚUnicodeDecodeErrorÚemailÚutilsÚencode_rfc2231)Únamer���r���Úresults��� `  r	���Úformat_header_param_rfc2231r*������s½���ø€�ó(�à‡MMð	1ô�	Øð�ô�ô�%œÔØ—‘˜WÓ%ˆäÓ/ YÔ/Ô/ؐ6˜˜E˜7 !Ð$ˆð	ØM‰M˜'Ô"ð�ˆMäK‰K×&Ñ& u¨gÓ6€E؈fBugÐ€Eà€Løô�#Ô$6Ð7ò�	Ùð	ús���ÁB�ÂB*Â)B*c����������������ó~���—�t��������|t��������«������r|j������������������d«������}|j������������������ddddœ«������}|�›�d|›�dS�)aí��
    Format and quote a single multipart header parameter.

    This follows the `WHATWG HTML Standard`_ as of 2021/06/10, matching
    the behavior of current browser and curl versions. Values are
    assumed to be UTF-8. The ``\n``, ``\r``, and ``"`` characters are
    percent encoded.

    .. _WHATWG HTML Standard:
        https://html.spec.whatwg.org/multipage/
        form-control-infrastructure.html#multipart-form-data

    :param name:
        The name of the parameter, an ASCII-only ``str``.
    :param value:
        The value of the parameter, a ``str`` or UTF-8 encoded
        ``bytes``.
    :returns:
        A string ``name="value"`` with the escaped value.

    .. versionchanged:: 2.0.0
        Matches the WHATWG HTML Standard as of 2021/06/10. Control
        characters are no longer percent encoded.

    .. versionchanged:: 2.0.0
        Renamed from ``format_header_param_html5`` and
        ``format_header_param``. The old names will be removed in
        urllib3 v2.1.0.
    r���z%0Az%0Dz%22)é
���é
���é"���r���r���)r���r���r ���Ú	translate)r(���r���s���  r	���Úformat_multipart_header_paramr0���O���sF���€�ô<�%œÔØ—‘˜WÓ%ˆð�
O‰O ¨E°uÑ=Ó>€E؈V2eW˜AÐÐr���c����������������óR���—�ddl�}|j������������������dt��������d¬«�������t��������|�|«������S�)ú„
    .. deprecated:: 2.0.0
        Renamed to :func:`format_multipart_header_param`. Will be
        removed in urllib3 v2.1.0.
    r���Nz€'format_header_param_html5' has been renamed to 'format_multipart_header_param'. The old name will be removed in urllib3 v2.1.0.r
���r���©r���r���r���r0���©r(���r���r���s���   r	���Úformat_header_param_html5r5���u���ó4���€�ó�à‡MMð	%ô�	Øð�ô�ô�)¨¨uÓ5Ð5r���c����������������óR���—�ddl�}|j������������������dt��������d¬«�������t��������|�|«������S�)r2���r���Nzz'format_header_param' has been renamed to 'format_multipart_header_param'. The old name will be removed in urllib3 v2.1.0.r
���r���r3���r4���s���   r	���Úformat_header_paramr8���‡���r6���r���c������������������ó”���—�e�Zd�ZdZ	�	�	�d		�	�	�	�	�	�	�	�	�d
d„Ze	�d	�	�	�	�	�	�	�dd„«�������Zd
d„Z	�	�	�	�dd„Zdd„Z		�	�	�d		�	�	�	�	�	�	�dd„Z
y)ÚRequestFieldaô��
    A data container for request body parameters.

    :param name:
        The name of this request field. Must be unicode.
    :param data:
        The data/value body.
    :param filename:
        An optional filename of the request field. Must be unicode.
    :param headers:
        An optional dict-like object of headers to initially use for the field.

    .. versionchanged:: 2.0.0
        The ``header_formatter`` parameter is deprecated and will
        be removed in urllib3 v2.1.0.
    Nc����������������óÂ���—�||�_���������||�_��������||�_��������i�|�_��������|rt	��������|«������|�_��������|$dd�l}|j
������������������dt��������d¬«�������||�_��������y�t��������|�_��������y�)Nr���zUThe 'header_formatter' parameter is deprecated and will be removed in urllib3 v2.1.0.r
���r���)
Ú_nameÚ	_filenameÚdataÚheadersÚdictr���r���r���Úheader_formatterr0���)Úselfr(���r>���r���r?���rA���r���s���       r	���Ú__init__zRequestField.__init__«���se���€�ð�ˆŒ
Ø!ˆŒØˆŒ	Ø.0ˆŒÙÜ ›=ˆDŒLàÐ'ÛàM‰Mð5ä"Øð	�
ô�
ð�%5ˆDÕ!ä$AˆDÕ!r���c����������������óº���—�t��������|t��������«������r&t��������|«������dk(��r|\��}}}n|\��}}t��������|«������}nd}d}|}�|�||||¬«������}|j	������������������|¬«�������|S�)a³��
        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.
        é���N)r���rA���)Úcontent_type)r���ÚtupleÚlenr
���Úmake_multipart)ÚclsÚ	fieldnamer���rA���r���r>���rF���Ú
request_params���        r	���Úfrom_tupleszRequestField.from_tuplesÇ���st���€�ô6�eœUÔ#ܐ5‹z˜QŠØ/4Ñ,˜$¡à!&‘˜$Ü1°(Ó;‘àˆH؈L؈DáØt hÐAQô
ˆ
ð�	×$Ñ$°,Ð$Ô?àÐr���c����������������ó&���—�|�j������������������||«������S�)a‹��
        Override this method to change how each multipart header
        parameter is formatted. By default, this calls
        :func:`format_multipart_header_param`.

        :param name:
            The name of the parameter, an ASCII-only ``str``.
        :param value:
            The value of the parameter, a ``str`` or UTF-8 encoded
            ``bytes``.

        :meta public:
        )rA���)rB���r(���r���s���   r	���Ú_render_partzRequestField._render_partô���s���€�ð�×$Ñ$ T¨5Ó1Ð1r���c����������������óÊ���—�g�}t��������|t��������«������r|j������������������«�������}n|}|D�])��\��}}|€Œ	|j������������������|�j	������������������||«������«�������Œ+�dj������������������|«������S�)aO��
        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) tuples or a :class:`dict` of (k, v) to format
            as `k1="v1"; k2="v2"; ...`.
        ú; )r���r@���ÚitemsÚappendrO���Újoin)rB���Úheader_partsÚpartsÚiterabler(���r���s���      r	���Ú
_render_partszRequestField._render_parts��sd���€�ð&�ˆÜl¤DÔ)Ø#×)Ñ)Ó+‰Hà#ˆHã#‰KˆD%ØÑ Ø—‘˜T×.Ñ.¨t°UÓ;Õ<ð�$ð�y‰y˜ÓÐr���c����������������ó`��—�g�}g�d¢}|D�]B��}|�j�������������������j������������������|d«������sŒ |j������������������|›�d|�j�������������������|���›�«�������ŒD�|�j�������������������j������������������«�������D�]#��\��}}||vsŒ|sŒ|j������������������|›�d|›�«�������Œ%�|j������������������d«�������dj	������������������|«������S�)z=
        Renders the headers for this request field.
        )úContent-DispositionúContent-TypeúContent-LocationFz: z
)r?���ÚgetrS���rR���rT���)rB���ÚlinesÚ	sort_keysÚsort_keyÚheader_nameÚheader_values���      r	���Úrender_headerszRequestField.render_headers#��sª���€�ð�ˆâOˆ	Û!ˆH؏|‰|×Ñ ¨%Õ0Ø—‘ ˜z¨¨D¯L©L¸Ñ,BÐ+CÐDÕEð�"ð�*.¯©×);Ñ);Ö)=Ñ%ˆK˜Ø )Ò+ÚØ—L‘L K =°°<°.Ð!AÕBð�*>ð
�	‰VÔ؏{‰{˜5Ó!Ð!r���c�����������	�����óä���—�|xs�ddj������������������d|�j������������������d|�j������������������fd|�j������������������ff«������g«������z���}||�j������������������d<���||�j������������������d<���||�j������������������d<���y	)
aó��
        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_disposition:
            The 'Content-Disposition' of the request body. Defaults to 'form-data'
        :param content_type:
            The 'Content-Type' of the request body.
        :param content_location:
            The 'Content-Location' of the request body.

        z	form-datarQ���Ú�r(���r���rZ���r[���r\���N)rT���rX���r<���r=���r?���)rB���Úcontent_dispositionrF���Úcontent_locations���    r	���rI���zRequestField.make_multipart6��s���€�ð(� 3ÒA°kÀTÇYÁYàØ×"Ñ"ؘdŸj™jÐ)¨J¸¿¹Ð+GÐHóð
óF
ñ�
Ðð�/Bˆ‰Ð*Ñ+Ø'3ˆ‰^Ñ$Ø+;ˆ‰Ð'Ò(r���)NNN)
r(���Ústrr>���Ú_TYPE_FIELD_VALUEr���ú
str | Noner?���ztyping.Mapping[str, str] | NonerA���ú5typing.Callable[[str, _TYPE_FIELD_VALUE], str] | Noner���)rK���rh���r���Ú_TYPE_FIELD_VALUE_TUPLErA���rk���Úreturnr:���©r(���rh���r���ri���rm���rh���)rU���z[dict[str, _TYPE_FIELD_VALUE | None] | typing.Sequence[tuple[str, _TYPE_FIELD_VALUE | None]]rm���rh���)rm���rh���)rf���rj���rF���rj���rg���rj���rm���ÚNone)Ú__name__Ú
__module__Ú__qualname__Ú__doc__rC���ÚclassmethodrM���rO���rX���rc���rI���r���r���r	���r:���r:���™���së���„�ñð*� $Ø37ØRVð
BàðBð� ðBð�ð	Bð
�1ðBð�Pó
Bð8�ð
�SWð	*àð*ð�'ð*ð�Pð	*ð
�
ò*ó�ð*óX2ð  ð
Dð ð�

ó
 ó>"ð*�+/Ø#'Ø'+ð	<à'ð<ð�!ð<ð�%ð	<ð
�
ô<r���r:���)zapplication/octet-stream)r���rj���r���rh���rm���rh���rn���)Ú
__future__r���Úemail.utilsr%���r���ÚtypingÚUnionrh���r���ri���ÚTuplerl���r
���r*���r0���r5���r8���r:���r���r���r	���ú<module>rz������s¦���ðÝ�"ã�Û�Û�
à—L‘L  e Ñ,Ð�Ø Ÿ,™,ØØ
‡LLÐ'Ð'Ñ(Ø
‡LLÐ'¨Ð,Ñ-ð/ñÐ�ð�*Dð
Øð
Ø#&ð
àó
ó -ó`#óL6ó$6÷$|<ò�|<r���