U
    Mf5                     @  s  U d dl mZ d dlZd dlZd dlZd dlZd dlZd dlmZm	Z	m
Z
mZmZ ddlmZmZ ddlmZ zddlmZ W n  ek
r   ddlmZ Y nX dd	d
ddddddddddgZG dd dejZejZejZejZejZej Z!ej"Z#eeefZ$ee!e#fZ%G dd dejZ&e&j'de&j(de&j)de&j*de&j+de&j,de&j-de&j.de&j/d e&j0d!e&j1d"e&j2d#e&j3d$e&j4d%e&j5d&iZ6d'e7d(< e&j'e&j(e&j)e&j*e&j-e&j.e&j/e&j0e&j1e&j2e&j3e&j4hZ8e&j'e&j(e&j+hZ9e:e;e<fZ=ej>G d)d dZ?d*d+d,d-dZ@d*d.d,d/dZAej>G d0d dZBdS )1    )annotationsN)Callable	GeneratorOptionalSequenceTuple   )
exceptions
extensions)Data)
apply_maskOpcodeOP_CONTOP_TEXT	OP_BINARYOP_CLOSEOP_PINGOP_PONGDATA_OPCODESCTRL_OPCODESFrameprepare_dataprepare_ctrlClosec                   @  s$   e Zd ZdZd\ZZZd\ZZZ	dS )r   z#Opcode values for WebSocket frames.)r   r      )   	   
   N)
__name__
__module____qualname____doc__CONTTEXTBINARYCLOSEPINGPONG r(   r(   5/tmp/pip-unpacked-wheel-yzabpfcc/websockets/frames.pyr   %   s   
c                   @  sL   e Zd ZdZdZdZdZdZdZdZ	dZ
d	Zd
ZdZdZdZdZdZdZdS )	CloseCodez-Close code values for WebSocket close frames.i  i  i  i  i  i  i  i  i  i  i  i  i  i  i  N)r   r   r    r!   NORMAL_CLOSURE
GOING_AWAYPROTOCOL_ERRORUNSUPPORTED_DATANO_STATUS_RCVDABNORMAL_CLOSUREINVALID_DATAPOLICY_VIOLATIONMESSAGE_TOO_BIGMANDATORY_EXTENSIONINTERNAL_ERRORSERVICE_RESTARTTRY_AGAIN_LATERBAD_GATEWAYTLS_HANDSHAKEr(   r(   r(   r)   r*   7   s    r*   OKz
going awayzprotocol errorzunsupported datazno status received [internal]zabnormal closure [internal]zinvalid frame payload datazpolicy violationzmessage too bigzmandatory extensionzinternal errorzservice restartztry again laterzbad gatewayz TLS handshake failure [internal]zdict[int, str]CLOSE_CODE_EXPLANATIONSc                   @  s   e Zd ZU dZded< ded< dZded< d	Zded
< d	Zded< d	Zded< ddddZ	e
dddddddddddZddddddddZdddd ZdS )!r   aN  
    WebSocket frame.

    Attributes:
        opcode: Opcode.
        data: Payload data.
        fin: FIN bit.
        rsv1: RSV1 bit.
        rsv2: RSV2 bit.
        rsv3: RSV3 bit.

    Only these fields are needed. The MASK bit, payload length and masking-key
    are handled on the fly when parsing and serializing frames.

    r   opcodebytesdataTboolfinFrsv1rsv2rsv3strreturnc              
   C  s  d}t | j dt | jdkr"dnd }| jr4dnd}| jtkrRt| j }n| jtkr| j}t |dkrd|dd	 d
|dd g}ddd |D }n| jt	krt
t| j}n| jrHzt| j }d}W nf ttfk
rD   | j}t |dkr(d|dd	 d
|dd g}ddd |D }d}Y nX nd}t |dkrv|dd d |dd  }dtd|||g}| jj d| d| dS )zE
        Return a human-readable representation of a frame.

        Nz byter    s	continued          s     i c                 s  s   | ]}|d V  qdS Z02xNr(   .0byter(   r(   r)   	<genexpr>   s     z Frame.__str__.<locals>.<genexpr>textc                 s  s   | ]}|d V  qdS rN   r(   rO   r(   r(   r)   rR      s     binaryz''K   0   z...iz, z [])lenr>   r@   r<   r   reprdecoder   joinr   rD   r   parseUnicodeDecodeErrorAttributeErrorfiltername)selfZcodinglengthZ	non_finalr>   rT   metadatar(   r(   r)   __str__   s6    &

 
 zFrame.__str__N)max_sizer
   z-Callable[[int], Generator[None, None, bytes]]zOptional[int]z(Optional[Sequence[extensions.Extension]]zGenerator[None, None, Frame])
read_exactmaskre   r
   rF   c             
   c  s  |dE dH }t d|\}}|d@ r*dnd}|d@ r:dnd}	|d@ rJdnd}
|d	@ rZdnd}zt|d
@ }W n. tk
r } ztd|W 5 d}~X Y nX |d@ rdnd|krtd|d@ }|dkr|dE dH }t d|\}n&|dkr|dE dH }t d|\}|dk	r<||kr<td| d| d|rP|dE dH }||E dH }|rnt||}| ||||	|
|}|dkrg }t|D ]}|j	||d}q|
  |S )a&  
        Parse a WebSocket frame.

        This is a generator-based coroutine.

        Args:
            read_exact: generator-based coroutine that reads the requested
                bytes or raises an exception if there isn't enough data.
            mask: whether the frame should be masked i.e. whether the read
                happens on the server side.
            max_size: maximum payload size in bytes.
            extensions: list of extensions, applied in reverse order.

        Raises:
            EOFError: if the connection is closed without a full WebSocket frame.
            UnicodeDecodeError: if the frame contains invalid UTF-8.
            PayloadTooBig: if the frame's payload size exceeds ``max_size``.
            ProtocolError: if the frame contains incorrect values.

        r   N!BB   TF@       rL      zinvalid opcodezincorrect masking   ~   !Hr   z!Qzover size limit (z > z bytes)   )re   )structunpackr   
ValueErrorr	   ProtocolErrorZPayloadTooBigr   reversedrZ   check)clsrf   rg   re   r
   r>   head1head2r@   rA   rB   rC   r<   excrb   
mask_bytesframe	extensionr(   r(   r)   r\      sF    



zFrame.parse)r
   )rg   r
   rF   c          
      C  s(  |    |dkrg }|D ]}|| } qt }| jr:dnd| jrFdndB | jrTdndB | jrbdndB | jB }|rvdnd}t	| j
}|dk r|td|||B  n>|d	k r|td
||dB | n|td||dB | |rtd}|| |rt| j
|}	n| j
}	||	 | S )aH  
        Serialize a WebSocket frame.

        Args:
            mask: whether the frame should be masked i.e. whether the write
                happens on the client side.
            extensions: list of extensions, applied in order.

        Raises:
            ProtocolError: if the frame contains incorrect values.

        Nri   r   rj   rk   rL   rn   rh   i   z!BBHz!BBQrm   rp   )rv   encodeioBytesIOr@   rA   rB   rC   r<   rX   r>   writerq   packsecretsZtoken_bytesr   getvalue)
ra   rg   r
   r}   outputrx   ry   rb   r{   r>   r(   r(   r)   	serialize  s>    



zFrame.serializeNonec                 C  sR   | j s| js| jrtd| jtkrNt| jdkr>td| j	sNtddS )z
        Check that reserved bits and opcode have acceptable values.

        Raises:
            ProtocolError: if a reserved bit or the opcode is invalid.

        zreserved bits must be 0}   zcontrol frame too longzfragmented control frameN)
rA   rB   rC   r	   rt   r<   r   rX   r>   r@   ra   r(   r(   r)   rv   L  s    


zFrame.check)r   r   r    r!   __annotations__r@   rA   rB   rC   rd   classmethodr\   r   rv   r(   r(   r(   r)   r   |   s   
/P;r   zTuple[int, bytes]r>   rF   c                 C  s6   t | trt| dfS t | tr*t| fS tddS )a  
    Convert a string or byte-like object to an opcode and a bytes-like object.

    This function is designed for data frames.

    If ``data`` is a :class:`str`, return ``OP_TEXT`` and a :class:`bytes`
    object encoding ``data`` in UTF-8.

    If ``data`` is a bytes-like object, return ``OP_BINARY`` and a bytes-like
    object.

    Raises:
        TypeError: if ``data`` doesn't have a supported type.

    utf-8data must be str or bytes-likeN)
isinstancerD   r   r~   	BytesLiker   	TypeErrorr>   r(   r(   r)   r   ^  s
    

r=   c                 C  s2   t | tr| dS t | tr&t| S tddS )ai  
    Convert a string or byte-like object to bytes.

    This function is designed for ping and pong frames.

    If ``data`` is a :class:`str`, return a :class:`bytes` object encoding
    ``data`` in UTF-8.

    If ``data`` is a bytes-like object, return a :class:`bytes` object.

    Raises:
        TypeError: if ``data`` doesn't have a supported type.

    r   r   N)r   rD   r~   r   r=   r   r   r(   r(   r)   r   v  s
    


c                   @  s`   e Zd ZU dZded< ded< ddddZed	d d
ddZd	dddZddddZ	dS )r   z
    Code and reason for WebSocket close frames.

    Attributes:
        code: Close code.
        reason: Close reason.

    intcoderD   reasonrE   c                 C  sz   d| j   krdk r n nd}n.d| j   kr6dk r@n nd}nt| j d}| j  d| d}| jrv| d	| j }|S )
zU
        Return a human-readable representation of a close code and reason.

          i  Z
registered  zprivate useunknownz ()rM   )r   r;   getr   )ra   Zexplanationresultr(   r(   r)   rd     s    zClose.__str__r=   r   c                 C  sp   t |dkrJtd|dd \}|dd d}| ||}|  |S t |dkrb| tjdS tddS )z
        Parse the payload of a close frame.

        Args:
            data: payload of the close frame.

        Raises:
            ProtocolError: if data is ill-formed.
            UnicodeDecodeError: if the reason isn't valid UTF-8.

        r   ro   Nr   r   rG   zclose frame too short)	rX   rq   rr   rZ   rv   r*   r/   r	   rt   )rw   r>   r   r   closer(   r(   r)   r\     s    
zClose.parsec                 C  s"   |    td| j| jd S )z:
        Serialize the payload of a close frame.

        ro   r   )rv   rq   r   r   r   r~   r   r(   r(   r)   r     s    zClose.serializer   c                 C  s0   | j tks,d| j   kr dk s,n tddS )z
        Check that the close code has a valid value for a close frame.

        Raises:
            ProtocolError: if the close code is invalid.

        r   r   zinvalid status codeN)r   EXTERNAL_CLOSE_CODESr	   rt   r   r(   r(   r)   rv     s    "zClose.checkN)
r   r   r    r!   r   rd   r   r\   r   rv   r(   r(   r(   r)   r     s   
	)C
__future__r   Zdataclassesenumr   r   rq   typingr   r   r   r   r   rG   r	   r
   r   Zspeedupsr   ImportErrorutils__all__IntEnumr   r"   r   r#   r   r$   r   r%   r   r&   r   r'   r   r   r   r*   r+   r,   r-   r.   r/   r0   r1   r2   r3   r4   r5   r6   r7   r8   r9   r;   r   r   ZOK_CLOSE_CODESr=   	bytearray
memoryviewr   Z	dataclassr   r   r   r   r(   r(   r(   r)   <module>   s    

               
 b