File: //opt/alt/python311/lib64/python3.11/http/__pycache__/client.cpython-311.opt-1.pyc
�
    �f��  �                   �N  � d Z ddlZddlZddlZddlZddlZddlZddlZddl	Z	ddl
Zddlm
Z
 g d�ZdZdZdZdZd	Zd
Z e�   �         �                    ej        j        �  �         d� ej        j        �                    �   �         D �   �         ZdZd
Z ej        d�  �        j        Z ej        d�  �        j         Z! ej        d�  �        Z" ej        d�  �        Z#h d�Z$d>d�Z%de&de&fd�Z' G d� dej(        j)        �  �        Z*d� Z+e*fd�Z, G d� dej-        �  �        Z. G d� d�  �        Z/	 ddl0Z0 G d � d!e/�  �        Z1e�2                    d!�  �         n# e3$ r Y nw xY w G d"� d#e4�  �        Z5 G d$� d%e5�  �        Z6 G d&� d'e5�  �        Z7 G d(� d)e5�  �        Z8 G d*� d+e5�  �        Z9 G d,� d-e5�  �        Z: G d.� d/e5�  �        Z; G d0� d1e5�  �        Z< G d2� d3e<�  �        Z= G d4� d5e<�  �        Z> G d6� d7e<�  �        Z? G d8� d9e5�  �        Z@ G d:� d;e5�  �        ZA G d<� d=eBe@�  �        ZCe5ZDdS )?a�
  HTTP/1.1 client library
<intro stuff goes here>
<other stuff, too>
HTTPConnection goes through a number of "states", which define when a client
may legally make another request or fetch the response for a particular
request. This diagram details these state transitions:
    (null)
      |
      | HTTPConnection()
      v
    Idle
      |
      | putrequest()
      v
    Request-started
      |
      | ( putheader() )*  endheaders()
      v
    Request-sent
      |\_____________________________
      |                              | getresponse() raises
      | response = getresponse()     | ConnectionError
      v                              v
    Unread-response                Idle
    [Response-headers-read]
      |\____________________
      |                     |
      | response.read()     | putrequest()
      v                     v
    Idle                  Req-started-unread-response
                     ______/|
                   /        |
   response.read() |        | ( putheader() )*  endheaders()
                   v        v
       Request-started    Req-sent-unread-response
                            |
                            | response.read()
                            v
                          Request-sent
This diagram presents the following rules:
  -- a second request may not be started until {response-headers-read}
  -- a response [object] cannot be retrieved until {request-sent}
  -- there is no differentiation between an unread response body and a
     partially read response body
Note: this enforcement is applied by the HTTPConnection class. The
      HTTPResponse class does not enforce this state machine, which
      implies sophisticated clients may accelerate the request/response
      pipeline. Caution should be taken, though: accelerating the states
      beyond the above pattern may imply knowledge of the server's
      connection-close behavior for certain requests. For example, it
      is impossible to tell whether the server will close the connection
      UNTIL the response headers have been read; this means that further
      requests cannot be placed into the pipeline until it is known that
      the server will NOT be closing the connection.
Logical State                  __state            __response
-------------                  -------            ----------
Idle                           _CS_IDLE           None
Request-started                _CS_REQ_STARTED    None
Request-sent                   _CS_REQ_SENT       None
Unread-response                _CS_IDLE           <response_class>
Req-started-unread-response    _CS_REQ_STARTED    <response_class>
Req-sent-unread-response       _CS_REQ_SENT       <response_class>
�    N)�urlsplit)�HTTPResponse�HTTPConnection�
HTTPException�NotConnected�UnknownProtocol�UnknownTransferEncoding�UnimplementedFileMode�IncompleteRead�
InvalidURL�ImproperConnectionState�CannotSendRequest�CannotSendHeader�ResponseNotReady�
BadStatusLine�LineTooLong�RemoteDisconnected�error�	responses�P   i�  �UNKNOWN�IdlezRequest-startedzRequest-sentc                 �   � i | ]
}||j         ��S � )�phrase)�.0�vs     �2/opt/alt/python311/lib64/python3.11/http/client.py�
<dictcomp>r   l   s   � �G�G�G�Q�Q���G�G�G�    i   �d   s   [^:\s][^:\r\n]*s   \n(?![ \t])|\r(?![ \t\n])z[ - ]z[ -]>   �PUT�POST�PATCH�datac           
      �   � 	 | �                     d�  �        S # t          $ r[}t          |j        |j        |j        |j        |�                    �   �         �d| |j        |j        �         d�d|�d��  �        d�d}~ww xY w)z<Call data.encode("latin-1") but show a better error message.�latin-1z (z.20z) is not valid Latin-1. Use z9.encode('utf-8') if you want to send it encoded in UTF-8.N)�encode�UnicodeEncodeError�encoding�object�start�end�title)r%   �name�errs      r   �_encoder1   �   s�   � �
E��{�{�9�%�%�%��� E� E� E� ��L��J��I��G� �Z�Z�\�\�\�\�4��	�#�'� 1�2�2�2�2�D�D�D�
:�;� ;� AE�	E�����E���s   � �
A<�AA7�7A<�enc_name�returnc                 �F   � | �                     d�  �        \  } }}|r| dz
  } | S )z)Remove interface scope from IPv6 address.�   %�   ])�	partition)r2   �percent�_s      r   �_strip_ipv6_ifacer:   �   s3   � �#�-�-�d�3�3��H�g�q�� ��D����Or    c                   �   � e Zd Zd� ZdS )�HTTPMessagec                 �8  � |�                     �   �         dz   }t          |�  �        }g }d}| �                    �   �         D ]Z}|d|�         �                     �   �         |k    rd}n|dd�         �                    �   �         sd}|r|�                    |�  �         �[|S )a�  Find all header lines matching a given header name.
        Look through the list of headers and find all lines matching a given
        header name (and their continuation lines).  A list of the lines is
        returned, without interpretation.  If the header does not occur, an
        empty list is returned.  If the header occurs multiple times, all
        occurrences are returned.  Case is not important in the header name.
        �:r   N�   )�lower�len�keys�isspace�append)�selfr/   �n�lst�hit�lines         r   �getallmatchingheadersz!HTTPMessage.getallmatchingheaders�   s�   � � �z�z�|�|�c�!����I�I�������I�I�K�K� 	!� 	!�D��B�Q�B�x�~�~���4�'�'�����"�1�"�X�%�%�'�'� 
���� 
!��
�
�4� � � ���
r    N)�__name__�
__module__�__qualname__rJ   r   r    r   r<