File: //lib/python3/dist-packages/future/backports/http/__pycache__/client.cpython-310.pyc
o
    ,�]�  �                
   @   s  d Z ddlmZmZmZmZ ddlmZmZm	Z	m
Z
 ddlmZ ddl
mZ ddl
mZ ddlmZ ddlZddlZddlZdd	lmZ ddlZdd
lmZ erWddlmZ nddlmZ g d�Zd
Z dZ!dZ"dZ#dZ$dZ%dZ&dZ'dZ(dZ)dZ*dZ+dZ,dZ-dZ.dZ/dZ0dZ1dZ2d Z3d!Z4d"Z5d#Z6d$Z7d%Z8d&Z9d'Z:d(Z;d)Z<d*Z=d+Z>d,Z?d-Z@d.ZAd/ZBd0ZCd1ZDd2ZEd3ZFd4ZGd5ZHd6ZId7ZJd8ZKd9ZLd:ZMd;ZNd<ZOd=ZPd>ZQd?ZRd@ZSdAZTdBZUdCZVdDZWdEZXdFZYdGZZi ddH�ddI�ddJ�ddK�ddL�ddM�ddN�ddO�ddP�ddQ�d dR�d!dS�d"dT�d#dU�d$dV�dWdX�d%dY�i d&dZ�d'd[�d(d\�d)d]�d*d^�d+d_�d,d`�d-da�d.db�d/dc�d0dd�d1de�d2df�d3dg�d4dh�d5di�d6dj��dkdldmdndodpdqdrdsdtdudv��Z[dwZ\dxZ]dZ^G dydz� dzej_�Z`e`fd{d|�Zaeb� ZcG d}d~� d~ejd�ZeG dd�� d�eb�ZfzddlgZgdd�lgmhZh W n
 ei�y�   Y nw G d�d�� d�ef�Zje�kd�� G d�d�� d�el�ZmG d�d�� d�em�ZnG d�d�� d�em�ZoG d�d�� d�em�ZpG d�d�� d�em�ZqG d�d�� d�em�ZrG d�d�� d�em�ZsG d�d�� d�em�ZtG d�d�� d�et�ZuG d�d�� d�et�ZvG d�d�� d�et�ZwG d�d�� d�em�ZxG d�d�� d�em�ZyemZzdS )�aD
  HTTP/1.1 client library
A backport of the Python 3.3 http/client.py module for python-future.
<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
      |
      | response = getresponse()
      v
    Unread-response   [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>
�    )�absolute_import�division�print_function�unicode_literals)�bytes�int�str�super)�PY2)�parser)�message)�create_connectionN)�urlsplit)�array)�Iterable)�HTTPResponse�HTTPConnection�
HTTPException�NotConnected�UnknownProtocol�UnknownTransferEncoding�UnimplementedFileMode�IncompleteRead�
InvalidURL�ImproperConnectionState�CannotSendRequest�CannotSendHeader�ResponseNotReady�
BadStatusLine�error�	responses�P   i�  �UNKNOWN�IdlezRequest-startedzRequest-sent�d   �e   �f   ��   ��   ��   ��   ��   ��   ��   ��   ��   i,  i-  i.  i/  i0  i1  i3  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  i�  �  i�  i�  i�  i�  �  �  �  ��  �  �  �  �  �  i�  i�  �  �ContinuezSwitching Protocols�OK�Created�AcceptedzNon-Authoritative Informationz
No Contentz
Reset ContentzPartial ContentzMultiple ChoiceszMoved Permanently�Foundz	See OtherzNot Modifiedz	Use Proxyi2  z(Unused)zTemporary RedirectzBad Request�UnauthorizedzPayment Required�	Forbiddenz	Not FoundzMethod Not AllowedzNot AcceptablezProxy Authentication RequiredzRequest Timeout�Conflict�GonezLength RequiredzPrecondition FailedzRequest Entity Too LargezRequest-URI Too LongzUnsupported Media TypezRequested Range Not SatisfiablezExpectation FailedzPrecondition RequiredzToo Many RequestszRequest Header Fields Too LargezInternal Server ErrorzNot ImplementedzBad GatewayzService UnavailablezGateway TimeoutzHTTP Version Not SupportedzNetwork Authentication Required)r0   r1   r2   r3   r4   r5   r6   r7   r8   r9   r:   i   i   c                   @   �   e Zd Zdd� ZdS )�HTTPMessagec                 C   sj   |� � d }t|�}g }d}| �� D ] }|d|� � � |kr!d}n
|dd� �� s+d}|r2|�|� q|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)�self�name�n�lst�hit�line� rS   �>/usr/lib/python3/dist-packages/future/backports/http/client.py�getallmatchingheaders�   s   
�z!HTTPMessage.getallmatchingheadersN)�__name__�
__module__�__qualname__rU   rS   rS   rS   rT   rE   �   s    rE   c                 C   s|   g }	 | � td �}t|�tkrtd��|�|� t|�tkr%tdt ��|dv r*nqtd��|��	d�}t
j|d��|�S )	aG  Parses only RFC2822 headers from a file pointer.
    email Parser wants to see strings rather than bytes.
    But a TextIOWrapper around self.rfile would buffer too many bytes
    from the stream, bytes which we later need to read as bytes.
    So we read the correct bytes here, as bytes, for email Parser
    to parse.
    TrG   �header linezgot more than %d headers��   
�   
�    r]   �
iso-8859-1)�_class)
�readline�_MAXLINErI   �LineTooLongrL   �_MAXHEADERSr   r   �join�decode�email_parser�Parser�parsestr)�fpr_   �headersrR   �hstringrS   rS   rT   �
parse_headers  s   
�	rl   c                       s�   e Zd Zdeddfdd�Zdd� Zdd� Zd	d
� Zdd� Z� fd
d�Z	� fdd�Z
dd� Zdd� Zd3� fdd�	Z
dd� Zdd� Zdd� Zdd� Zdd � Zd!d"� Zd#d$� Zd%d&� Zd3d'd(�Zd)d*� Zd+d,� Zd-d.� Zd/d0� Zd1d2� Z�  ZS )4r   r   Nc                 C   sh   |� d�| _|| _|turt�dtd� || _d  | _| _	t
| _t
| _t
| _
t
| _t
| _t
| _t
| _d S )N�rb�ithe 'strict' argument isn't supported anymore; http.client now always assumes HTTP/1.x compliant servers.�   )�makefileri   �
debuglevel�_strict_sentinel�warnings�warn�DeprecationWarning�_methodrj   �msg�_UNKNOWN�version�status�reason�chunked�
chunk_left�length�
will_close)rM   �sockrq   �strict�method�urlrS   rS   rT   �__init__*  s   �
zHTTPResponse.__init__c                 C   s  t | j�td �d�}t|�tkrtd��| jdkr!tdt|�� |s't	|��z|�
d d�\}}}W n! tyS   z|�
d d�\}}d}W n tyP   d}Y nw Y nw |�d�sa| �
�  t	|��zt|�}|d	k sn|d
krrt	|��W n ty~   t	|��w |||fS )NrG   r^   zstatus liner   zreply:ro   � zHTTP/r$   i�  )r   ri   r`   ra   rI   rb   rq   �print�reprr   �split�
ValueError�
startswith�_close_connr   )rM   rR   ry   rz   r{   rS   rS   rT   �_read_statusL  s<