o
    Rh3                     @  s  d dl mZ d dlZd dlmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZmZmZmZmZmZmZmZmZmZmZmZ dd	lmZ g d
ZddddddddddeddddddFd1d2ZeddddddddddeddddddGd4d5Zdddddddddedd6dHd7d8Zdddddddddedd6dHd9d:Zdddddddddedd6dHd;d<Zdddddddddddddedd=dId>d?Z dddddddddddddedd=dId@dAZ!dddddddddddddedd=dIdBdCZ"dddddddddedd6dHdDdEZ#dS )J    )annotationsN)contextmanager   )Client)DEFAULT_TIMEOUT_CONFIG)Response)	AuthTypes	CertTypesCookieTypesHeaderTypesProxiesTypes
ProxyTypesQueryParamTypesRequestContentRequestDataRequestFilesTimeoutTypesVerifyTypes)URL)	deletegetheadoptionspatchpostputrequeststreamFT)paramscontentdatafilesjsonheaderscookiesauthproxyproxiestimeoutfollow_redirectsverifycert	trust_envmethodstrurl	URL | strr   QueryParamTypes | Noner   RequestContent | Noner    RequestData | Noner!   RequestFiles | Noner"   typing.Any | Noner#   HeaderTypes | Noner$   CookieTypes | Noner%   AuthTypes | Noner&   ProxyTypes | Noner'   ProxiesTypes | Noner(   r   r)   boolr*   r   r+   CertTypes | Noner,   returnr   c                C  sX   t ||
|||||d}|j| ||||||||	|d
W  d   S 1 s%w   Y  dS )a  
    Sends an HTTP request.

    **Parameters:**

    * **method** - HTTP method for the new `Request` object: `GET`, `OPTIONS`,
    `HEAD`, `POST`, `PUT`, `PATCH`, or `DELETE`.
    * **url** - URL for the new `Request` object.
    * **params** - *(optional)* Query parameters to include in the URL, as a
    string, dictionary, or sequence of two-tuples.
    * **content** - *(optional)* Binary content to include in the body of the
    request, as bytes or a byte iterator.
    * **data** - *(optional)* Form data to include in the body of the request,
    as a dictionary.
    * **files** - *(optional)* A dictionary of upload files to include in the
    body of the request.
    * **json** - *(optional)* A JSON serializable object to include in the body
    of the request.
    * **headers** - *(optional)* Dictionary of HTTP headers to include in the
    request.
    * **cookies** - *(optional)* Dictionary of Cookie items to include in the
    request.
    * **auth** - *(optional)* An authentication class to use when sending the
    request.
    * **proxy** - *(optional)* A proxy URL where all the traffic should be routed.
    * **proxies** - *(optional)* A dictionary mapping proxy keys to proxy URLs.
    * **timeout** - *(optional)* The timeout configuration to use when sending
    the request.
    * **follow_redirects** - *(optional)* Enables or disables HTTP redirects.
    * **verify** - *(optional)* SSL certificates (a.k.a CA bundle) used to
    verify the identity of requested hosts. Either `True` (default CA bundle),
    a path to an SSL certificate file, an `ssl.SSLContext`, or `False`
    (which will disable verification).
    * **cert** - *(optional)* An SSL certificate used by the requested host
    to authenticate the client. Either a path to an SSL certificate file, or
    two-tuple of (certificate file, key file), or a three-tuple of (certificate
    file, key file, password).
    * **trust_env** - *(optional)* Enables or disables usage of environment
    variables for configuration.

    **Returns:** `Response`

    Usage:

    ```
    >>> import httpx
    >>> response = httpx.request('GET', 'https://httpbin.org/get')
    >>> response
    <Response [200 OK]>
    ```
    r$   r&   r'   r+   r*   r(   r,   
r-   r/   r   r    r!   r"   r   r#   r%   r)   N)r   r   )r-   r/   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   client rA   L/home/air/sanwanet/backup_V2/venv/lib/python3.10/site-packages/httpx/_api.pyr   &   s.   G$r   typing.Iterator[Response]c                c  s    t ||
|||||d3}|j| ||||||||	|d
}|V  W d   n1 s*w   Y  W d   dS W d   dS 1 sBw   Y  dS )z
    Alternative to `httpx.request()` that streams the response body
    instead of loading it into memory at once.

    **Parameters**: See `httpx.request`.

    See also: [Streaming Responses][0]

    [0]: /quickstart#streaming-responses
    r>   r?   N)r   r   )r-   r/   r   r   r    r!   r"   r#   r$   r%   r&   r'   r(   r)   r*   r+   r,   r@   responserA   rA   rB   r      s:   	"r   r   r#   r$   r%   r&   r'   r)   r+   r*   r(   r,   c                C  "   t d| |||||||||	|
|dS )z
    Sends a `GET` request.

    **Parameters**: See `httpx.request`.

    Note that the `data`, `files`, `json` and `content` parameters are not available
    on this function, as `GET` requests should not include a request body.
    GETrE   r   r/   r   r#   r$   r%   r&   r'   r)   r+   r*   r(   r,   rA   rA   rB   r         r   c                C  rF   )z
    Sends an `OPTIONS` request.

    **Parameters**: See `httpx.request`.

    Note that the `data`, `files`, `json` and `content` parameters are not available
    on this function, as `OPTIONS` requests should not include a request body.
    OPTIONSrE   rH   rI   rA   rA   rB   r      rJ   r   c                C  rF   )z
    Sends a `HEAD` request.

    **Parameters**: See `httpx.request`.

    Note that the `data`, `files`, `json` and `content` parameters are not available
    on this function, as `HEAD` requests should not include a request body.
    HEADrE   rH   rI   rA   rA   rB   r     rJ   r   r   r    r!   r"   r   r#   r$   r%   r&   r'   r)   r+   r*   r(   r,   c                C  .   t d| f|||||||||	|
|||||dS )zK
    Sends a `POST` request.

    **Parameters**: See `httpx.request`.
    POSTrM   rH   r/   r   r    r!   r"   r   r#   r$   r%   r&   r'   r)   r+   r*   r(   r,   rA   rA   rB   r   3  (   r   c                C  rN   )zJ
    Sends a `PUT` request.

    **Parameters**: See `httpx.request`.
    PUTrM   rH   rP   rA   rA   rB   r   `  rQ   r   c                C  rN   )zL
    Sends a `PATCH` request.

    **Parameters**: See `httpx.request`.
    PATCHrM   rH   rP   rA   rA   rB   r     rQ   r   c                C  rF   )z
    Sends a `DELETE` request.

    **Parameters**: See `httpx.request`.

    Note that the `data`, `files`, `json` and `content` parameters are not available
    on this function, as `DELETE` requests should not include a request body.
    DELETErE   rH   rI   rA   rA   rB   r     rJ   r   )$r-   r.   r/   r0   r   r1   r   r2   r    r3   r!   r4   r"   r5   r#   r6   r$   r7   r%   r8   r&   r9   r'   r:   r(   r   r)   r;   r*   r   r+   r<   r,   r;   r=   r   )$r-   r.   r/   r0   r   r1   r   r2   r    r3   r!   r4   r"   r5   r#   r6   r$   r7   r%   r8   r&   r9   r'   r:   r(   r   r)   r;   r*   r   r+   r<   r,   r;   r=   rC   )r/   r0   r   r1   r#   r6   r$   r7   r%   r8   r&   r9   r'   r:   r)   r;   r+   r<   r*   r   r(   r   r,   r;   r=   r   )"r/   r0   r   r2   r    r3   r!   r4   r"   r5   r   r1   r#   r6   r$   r7   r%   r8   r&   r9   r'   r:   r)   r;   r+   r<   r*   r   r(   r   r,   r;   r=   r   )$
__future__r   typing
contextlibr   _clientr   _configr   _modelsr   _typesr   r	   r
   r   r   r   r   r   r   r   r   r   _urlsr   __all__r   r   r   r   r   r   r   r   r   rA   rA   rA   rB   <module>   s   8^9+++000