
    i3                         d Z ddlmZ ddlmZ ddlZddlmZ ddlm	Z	 ddl
mZmZmZ ddlmZmZ dd	lmZ dd
lmZ  e	ed          Z G d de          ZdS )zSThis module contains methods to make POST and GET requests using the httpx library.    )
Collection)AnyN)DefaultValue)
get_logger)HTTPVersionODVInput	SocketOpt)NetworkErrorTimedOut)BaseRequest)RequestDataHTTPXRequestc                      e Zd ZdZdZ	 	 	 	 	 	 	 	 	 	 dd	ed
edz  dedz  dedz  dedz  dedee	         dz  de
ej        z  ej        z  dz  dedz  dee
ef         dz  fdZede
fd            Zededz  fd            Zdej        fdZddZddZdej        ej        ej        ej        fde
de
dedz  d
ee         dee         dee         dee         deeef         fdZdS ) r   a  Implementation of :class:`~telegram.request.BaseRequest` using the library
    `httpx <https://www.python-httpx.org>`_.

    .. versionadded:: 20.0

    .. versionchanged:: 22.0
        Removed the deprecated parameter ``proxy_url``. Use :paramref:`proxy` instead.

    Args:
        connection_pool_size (:obj:`int`, optional): Number of connections to keep in the
            connection pool. Defaults to ``256``.

            .. versionchanged:: 22.4
                Set the default to ``256``.
                Stopped applying to ``httpx.Limits.max_keepalive_connections``. Now only applies to
                ``httpx.Limits.max_connections``. See `Resource Limits
                <https://www.python-httpx.org/advanced/resource-limits/>`_
        read_timeout (:obj:`float` | :obj:`None`, optional): If passed, specifies the maximum
            amount of time (in seconds) to wait for a response from Telegram's server.
            This value is used unless a different value is passed to :meth:`do_request`.
            Defaults to ``5``.
        write_timeout (:obj:`float` | :obj:`None`, optional): If passed, specifies the maximum
            amount of time (in seconds) to wait for a write operation to complete (in terms of
            a network socket; i.e. POSTing a request or uploading a file).
            This value is used unless a different value is passed to :meth:`do_request`.
            Defaults to ``5``.

            Hint:
                This timeout is used for all requests except for those that upload media/files.
                For the latter, :paramref:`media_write_timeout` is used.
        connect_timeout (:obj:`float` | :obj:`None`, optional): If passed, specifies the
            maximum amount of time (in seconds) to wait for a connection attempt to a server
            to succeed. This value is used unless a different value is passed to
            :meth:`do_request`. Defaults to ``5``.
        pool_timeout (:obj:`float` | :obj:`None`, optional): If passed, specifies the maximum
            amount of time (in seconds) to wait for a connection to become available.
            This value is used unless a different value is passed to :meth:`do_request`.
            Defaults to ``1``.

            Warning:
                With a finite pool timeout, you must expect :exc:`telegram.error.TimedOut`
                exceptions to be thrown when more requests are made simultaneously than there are
                connections in the connection pool!
        http_version (:obj:`str`, optional): If ``"2"`` or ``"2.0"``, HTTP/2 will be used instead
            of HTTP/1.1. Defaults to ``"1.1"``.

            .. versionadded:: 20.1
            .. versionchanged:: 20.2
                Reset the default version to 1.1.

            .. versionchanged:: 20.5
                Accept ``"2"`` as a valid value.
        socket_options (Collection[:obj:`tuple`], optional): Socket options to be passed to the
            underlying `library             <https://www.encode.io/httpcore/async/#httpcore.AsyncConnectionPool.__init__>`_.

            Note:
                The values accepted by this parameter depend on the operating system.
                This is a low-level parameter and should only be used if you are familiar with
                these concepts.

            .. versionadded:: 20.7
        proxy (:obj:`str` | ``httpx.Proxy`` | ``httpx.URL``, optional): The URL to a proxy server,
            a ``httpx.Proxy`` object or a ``httpx.URL`` object. For example
            ``'http://127.0.0.1:3128'`` or ``'socks5://127.0.0.1:3128'``. Defaults to :obj:`None`.

            Note:
                * The proxy URL can also be set via the environment variables ``HTTPS_PROXY`` or
                  ``ALL_PROXY``. See `the docs of httpx`_ for more info.
                * HTTPS proxies can be configured by passing a ``httpx.Proxy`` object with
                  a corresponding ``ssl_context``.
                * For Socks5 support, additional dependencies are required. Make sure to install
                  PTB via :command:`pip install "python-telegram-bot[socks]"` in this case.
                * Socks5 proxies can not be set via environment variables.

            .. _the docs of httpx: https://www.python-httpx.org/environment_variables/#proxies

            .. versionadded:: 20.7
        media_write_timeout (:obj:`float` | :obj:`None`, optional): Like :paramref:`write_timeout`,
            but used only for requests that upload media/files. This value is used unless a
            different value is passed to :paramref:`do_request.write_timeout` of
            :meth:`do_request`. Defaults to ``20`` seconds.

            .. versionadded:: 21.0
        httpx_kwargs (dict[:obj:`str`, Any], optional): Additional keyword arguments to be passed
            to the `httpx.AsyncClient <https://www.python-httpx.org/api/#asyncclient>`_
            constructor.

            Warning:
                This parameter is intended for advanced users that want to fine-tune the behavior
                of the underlying ``httpx`` client. The values passed here will override all the
                defaults set by ``python-telegram-bot`` and all other parameters passed to
                :class:`HTTPXRequest`. The only exception is the :paramref:`media_write_timeout`
                parameter, which is not passed to the client constructor.
                No runtime warnings will be issued about parameters that are overridden in this
                way.

            .. versionadded:: 21.6

    )_client_client_kwargs_http_version_media_write_timeout         @      ?1.1N      4@connection_pool_sizeread_timeoutwrite_timeoutconnect_timeoutpool_timeouthttp_versionsocket_optionsproxymedia_write_timeouthttpx_kwargsc                    || _         |	| _        t          j        ||||          }t          j        |          }|dvrt          d          |dk    }|| d}|rt          j        |          nd }||||d||
pi | _        	 |                                 | _	        d S # t          $ rY}d	t          |          vrd
t          |          vr d
t          |          v rt          d          |t          d          |d }~ww xY w)Nconnectreadwritepool)max_connections)r   2z2.0z2`http_version` must be either '1.1', '2.0' or '2'.r   )http1http2)r   )timeoutr    limits	transportzhttpx[http2]zhttpx[socks]z\To use Socks5 proxies, PTB must be installed via `pip install "python-telegram-bot[socks]"`.zTTo use HTTP/2, PTB must be installed via `pip install "python-telegram-bot[http2]"`.)r   r   httpxTimeoutLimits
ValueErrorAsyncHTTPTransportr   _build_clientr   ImportErrorstrRuntimeError)selfr   r   r   r   r   r   r   r    r!   r"   r-   r.   r+   http_kwargsr/   excs                    ^/Users/shanyulin/my-agent/.venv/lib/python3.11/site-packages/telegram/request/_httpxrequest.py__init__zHTTPXRequest.__init__   s    *$7!-#	
 
 
 0
 
 
 222QRRR% %E	::
 E$-     	 "	
 

 
 !r
	--//DLLL 	 	 	SXX--.C2P2PS))"5   1  	s   B" "
D,AD  Dreturnc                     | j         S )zn
        :obj:`str`: Used HTTP version, see :paramref:`http_version`.

        .. versionadded:: 20.2
        )r   r9   s    r<   r   zHTTPXRequest.http_version   s     !!    c                 $    | j         j        j        S )zSee :attr:`BaseRequest.read_timeout`.

        Returns:
            :obj:`float` | :obj:`None`: The default read timeout in seconds as passed to
                :paramref:`HTTPXRequest.read_timeout`.
        )r   r-   r&   r@   s    r<   r   zHTTPXRequest.read_timeout   s     |#((rA   c                 .    t          j        di | j        S )N )r0   AsyncClientr   r@   s    r<   r5   zHTTPXRequest._build_client   s     774#6777rA   c                 X   K   | j         j        r|                                 | _         dS dS )z#See :meth:`BaseRequest.initialize`.N)r   	is_closedr5   r@   s    r<   
initializezHTTPXRequest.initialize   s4      <! 	0--//DLLL	0 	0rA   c                    K   | j         j        rt                              d           dS | j                                          d{V  dS )z!See :meth:`BaseRequest.shutdown`.z2This HTTPXRequest is already shut down. Returning.N)r   rG   _LOGGERdebugacloser@   s    r<   shutdownzHTTPXRequest.shutdown   sW      <! 	MMNOOOFl!!###########rA   urlmethodrequest_datac                 L  K   | j         j        rt          d          |r|j        nd}|r|j        nd}	t          |t                    r| j         j        j        }t          |t                    r| j         j        j	        }t          |t                    r| j         j        j
        }t          |t                    r|s| j         j        j        n| j        }t          j        ||||          }
	 | j                             ||d| j        i|
||	           d{V }n|# t          j        $ r8}t          |t          j                  rt'          d          |t&          |d}~wt          j        $ r%}t+          d|j        j         d	|           |d}~ww xY w|j        |j        fS )
z#See :meth:`BaseRequest.do_request`.z%This HTTPXRequest is not initialized!Nr$   z
User-Agent)rO   rN   headersr-   filesdatazPool timeout: All connections in the connection pool are occupied. Request was *not* sent to Telegram. Consider adjusting the connection pool size or the pool timeout.)messagezhttpx.z: )r   rG   r8   multipart_datajson_parameters
isinstancer   r-   r&   r%   r(   r'   r   r0   r1   request
USER_AGENTTimeoutExceptionPoolTimeoutr   	HTTPErrorr
   	__class____name__status_codecontent)r9   rN   rO   rP   r   r   r   r   rS   rT   r-   reserrs                r<   
do_requestzHTTPXRequest.do_request   s      <! 	HFGGG/;E++/;E|++ lL11 	5</4Lo|44 	;"l2:OlL11 	5</4Lm\22 	c>CbDL066IbM-#	
 
 
	R,,%t7 -        CC % 		$ 		$ 		$#u011 9    # 	R 	R 	R G(>GG#GGHHcQ	R ++s$   .-D F+3EF0 FF)
r   r   r   r   r   r   NNr   N)r>   N)r_   
__module____qualname____doc__	__slots__intfloatr   r   r	   r7   r0   ProxyURLdictr   r=   propertyr   r   rE   r5   rH   rM   r   DEFAULT_NONEr   r   tuplebytesrd   rD   rA   r<   r   r   )   s=       c cJ WI %(%(&)(+%($)7;6:,0.2< <!< dl< t|	<
 < dl< "< #9-4< U[ 59,t3< #T\< 38nt+< < < <| "c " " " X" )edl ) ) ) X)8u0 8 8 8 80 0 0 0
$ $ $ $ ,0(3(@)4)A+6+C(3(@?, ?,?, ?, "D(	?,
 uo?,  ?, "%?, uo?, 
sEz	?, ?, ?, ?, ?, ?,rA   )rg   collections.abcr   typingr   r0   telegram._utils.defaultvaluer   telegram._utils.loggingr   telegram._utils.typesr   r   r	   telegram.errorr
   r   telegram.request._baserequestr   telegram.request._requestdatar   r_   rJ   r   rD   rA   r<   <module>rz      s
  & Z Y & & & & & &        5 5 5 5 5 5 . . . . . . B B B B B B B B B B 1 1 1 1 1 1 1 1 5 5 5 5 5 5 5 5 5 5 5 5 *X~
.
.H, H, H, H, H,; H, H, H, H, H,rA   