
    lϞi84                       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Zd dl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 d dlmZ d dlmZ d dlmZmZ d dlZd dlmZ d dlmZ er1d d	lmZ d d
lm Z  d dl!m"Z" d dl#m$Z$ d dl%m&Z& ee z  e&z  e"z  e$z  Z'de(d<   e	jR                  e	jT                  fZ+ej                  dk(  re+e	jX                  fz  Z+ ejZ                  d      Z. G d d      Z/ G d d      Z0y)    )annotationsN)	GeneratorSequence)
formatdate)	FrameType)TYPE_CHECKING	TypeAlias)asyncio_run)Config)H11Protocol)HttpToolsProtocol)WebSocketProtocol)WebSocketsSansIOProtocol)
WSProtocolr	   	Protocolswin32zuvicorn.errorc                      e Zd ZdZddZy)ServerStatezP
    Shared servers state that is available between all protocol instances.
    c                \    d| _         t               | _        t               | _        g | _        y Nr   )total_requestssetconnectionstasksdefault_headersselfs    P/var/www/html/jploft-chatbot/venv/lib/python3.12/site-packages/uvicorn/server.py__init__zServerState.__init__1   s%    +.5.1e
:<    NreturnNone)__name__
__module____qualname____doc__r    r    r   r   r   ,   s    =r    r   c                      e Zd ZddZej
                  dd       ZdddZdddZdddZ	dddZ
ddZdd	Zdd
ZdddZddZej"                  dd       ZddZy)Serverc                v    || _         t               | _        d| _        d| _        d| _        d| _        g | _        y )NFg        )configr   server_statestartedshould_exit
force_exitlast_notified_captured_signals)r   r,   s     r   r   zServer.__init__9   s9    'M  ,.r    c                    | j                   j                  y | j                   j                  t        j                  d| j                   j                        z   S r   )r,   limit_max_requestsrandomrandintlimit_max_requests_jitterr   s    r   r4   zServer.limit_max_requestsD   s?    ;;))1{{--q$++BgBg0hhhr    Nc                l    t        | j                  |      | j                  j                               S )Nsockets)loop_factory)r
   server,   get_loop_factoryr   r:   s     r   runz
Server.runJ   s'    4::g:6T[[EaEaEcddr    c                   K   | j                         5  | j                  |       d {    d d d        y 7 # 1 sw Y   y xY wwN)capture_signals_server>   s     r   r<   zServer.serveM   sA     !!# 	'++g&&&	' 	'&	' 	's$   A868	A8AAc                j  K   t        j                         }| j                  }|j                  s|j	                          |j                  |      | _        d}dt        j                  dd      z   dz   }t        j                  ||d|i       | j                  |	       d {    | j                  s| j                          d {    | j                  rT| j                  |	       d {    d
}dt        j                  dd      z   dz   }t        j                  ||d|i       y y 7 7 g7 Cw)NzStarted server process [%d]zStarted server process [z%dcyan)fg]color_messageextrar9   zFinished server process [%d]zFinished server process [)osgetpidr,   loadedloadlifespan_classlifespanclickstyleloggerinfostartupr/   	main_loopr.   shutdown)r   r:   
process_idr,   messagerH   s         r   rC   zServer._serveQ   s    YY[
}}KKM--f5/2U[[&5QQTWWGZ/OPll7l+++.."""<<---0004G7%++dv:VVY\\MKKO]3SKT  	,"0s7   B!D3#D-$#D3D/%D3-D1.A D3/D31D3c                   K    j                   j                          d {     j                   j                  rd _        y  j                  	 d
	 	 	 d fd}t	        j
                         }|	 	 	 	 dd}g  _        |D ]~  }t        j                         dk(  }j                  dkD  r
|r ||      }|j                  ||j                  j                         d {   } j                  j                  |        |}nj                  t        j                   j                  t        j"                  t        j$                        }|j                  ||j                  j                         d {   }|j&                  J |j&                  }|g _        nGj(                  d}	t*        j,                  j/                  j(                        r)t+        j0                  j(                        j2                  }	|j5                  |j(                  j                  j                         d {   }t+        j6                  j(                  |	       |j&                  J |j&                  }|g _        ni	 |j                  |j8                  j:                  j                  j                  	       d {   }j&                  J |j&                  }|g _        | jI                  |       d _%        y 	 d _%        y 7 7 27 7 7 U# t<        $ rW}
t>        jA                  |
        j                   jC                          d {  7   tE        jF                  d       Y d }
~
d }
~
ww xY ww)NTc                j    j                  j                  j                  j                  |       S )N)r,   r-   	app_state_loop)http_protocol_classr-   rP   state)r]   r,   r   s    r   create_protocolz'Server.startup.<locals>.create_protocolp   s9     --!..----	 .  r    c                d    ddl m} | j                  t        j                               } ||      S )Nr   )	fromshare)socketrb   sharerK   rL   )sockrb   	sock_datas      r   _share_socketz%Server.startup.<locals>._share_socket   s&    
 - JJryy{3	 ++r    Windows   )re   sslbacklogi  )pathrj   rk   )hostportrj   rk   rA   )r]   z asyncio.AbstractEventLoop | Noner"   zasyncio.Protocol)re   socket.SocketTyper"   ro   )&rP   rU   r/   r,   asyncioget_running_loopserversplatformsystemworkerscreate_serverrj   rk   appendfdrc   fromfdAF_UNIXSOCK_STREAMr:   udsrK   rl   existsstatst_modecreate_unix_serverchmodrm   rn   OSErrorrS   errorrW   sysexit_log_started_messager.   )r   r:   r`   looprg   re   
is_windowsserver	listeners	uds_permsexcr,   s   `          @r   rU   zServer.startuph   s    mm##%%%==$$#D 7;	3		 '') ,',", >@DL ,%__.);
>>A%*(.D#11/RXR\R\flftft1uu##F+,  IYY"==FNNF<N<NOD--oDfjjbhbpbp-qqF>>---I"8DLZZ#Iww~~fjj)GGFJJ/77	22fjjfjj&.. 3  F HHVZZ+>>---I"8DL#11#

"NN  2    >>---I"8DL?%%i0  u 	&N v r  S!mm,,...s   NLC N#L$BN>L?B>N=L>ANAL LL ANNNNL 	M?(2M:MM:5N:M??Nc                   | j                   }|j                  *|d   }t        j                  d|j	                                y |j
                  !t        j                  d|j
                         y d}|j                  dn|j                  }d|v rd}|j                  }|dk(  r|d   j	                         d   }|j                  rd	nd
}d| d}dt        j                  |d      z   dz   }	t        j                  ||||d|	i       y )Nr   z3Uvicorn running on socket %s (Press CTRL+C to quit)z8Uvicorn running on unix socket %s (Press CTRL+C to quit)z
%s://%s:%dz0.0.0.0:z%s://[%s]:%dri   httpshttpzUvicorn running on z (Press CTRL+C to quit)T)boldrH   rI   )r,   rx   rS   rT   getsocknamer|   rm   rn   rj   rQ   rR   )
r   r   r,   re   addr_formatrm   rn   protocol_namerY   rH   s
             r   r   zServer._log_started_message   s   99 Q<DKKE  "
 ZZ#KKRTZT^T^_ 'K & 39Dd{,;;Dqy |//1!4'-zzGvM+K=8OPG1EKKRV4WWZssMKK&6  r    c                   K   d}| j                  |       d {   }|sD|dz  }|dz  }t        j                  d       d {    | j                  |       d {   }|sCy y 7 K7 $7 w)Nr   ri   i / 皙?)on_tickrp   sleep)r   counterr/   s      r   rV   zServer.main_loop   si      LL11qLG&G--$$$ $W 55K	  2 %5s9   A+A%(A+A'A+A)A+#A+'A+)A+c                j  K   |dz  dk(  rt        j                          }t        |d      j                         }| j                  j                  rd|fg}ng }|| j                  j
                  z   | j                  _        | j                  j                  O|| j                  z
  | j                  j                  kD  r)|| _	        | j                  j                          d {    | j                  ry| j                  }|0| j                  j                  |k\  rt        j                  d|       yy7 Pw)N
   r   T)usegmts   datez:Maximum request limit of %d exceeded. Terminating process.F)timer   encoder,   date_headerencoded_headersr-   r   callback_notifyr1   timeout_notifyr/   r4   r   rS   rT   )r   r   current_timecurrent_dater   max_requestss         r   r   zServer.on_tick   s    R<199;L%l4@GGIL{{&& '67 0;dkk>Y>Y0YD- {{**6$"4"44t{{7Q7QQ)5D&++55777 ..#(9(9(H(HL(XKKTVbc 8s   CD3 D1!AD3c                0  K   t         j                  d       | j                  D ]  }|j                           |xs g D ]  }|j                           t	        | j
                  j                        D ]  }|j                           t        j                  d       d {    	 t        j                  | j                         | j                  j                         d {    | j&                  s#| j(                  j                          d {    y y 7 v7 6# t        j                  $ rc t         j                  dt!        | j
                  j"                               | j
                  j"                  D ]  }|j%                  d        Y w xY w7 w)NzShutting downr   )timeoutz=Cancel %s running task(s), timeout graceful shutdown exceededz2Task cancelled, timeout graceful shutdown exceeded)msg)rS   rT   rr   closelistr-   r   rW   rp   r   wait_for_wait_tasks_to_completer,   timeout_graceful_shutdownTimeoutErrorr   lenr   cancelr0   rP   )r   r:   r   re   
connectionts         r   rW   zServer.shutdown  sa    O$ ll 	FLLN	Mr 	DJJL	 t00<<= 	"J!	"mmC   	S"",,.==   --((*** # 	! ## 	SLLOD%%++, &&,, SQRS	S +sU   BF D!F&<D "D#D ')FFFD A3FFFFc                  K   | j                   j                  r| j                  syd}t        j	                  |       | j                   j                  rL| j                  s@t        j                  d       d {    | j                   j                  r| j                  s@| j                   j                  r| j                  syd}t        j	                  |       | j                   j                  rL| j                  s@t        j                  d       d {    | j                   j                  r| j                  s@| j                  D ]  }|j                          d {     y 7 7 S7 w)Nz8Waiting for connections to close. (CTRL+C to force quit)r   z@Waiting for background tasks to complete. (CTRL+C to force quit))
r-   r   r0   rS   rT   rp   r   r   rr   wait_closed)r   r   r   s      r   r   zServer._wait_tasks_to_complete/  s    ((LCKK##//mmC((( ##// ""4??TCKK##))$//mmC((( ##))$// ll 	'F$$&&&	' ) ) 'sC   A4E)6E#7&E)A3E)E%&E)9"E)E'E)%E)'E)c              #     K   t        j                         t        j                         urd  y t        D ci c]#  }|t	        j                  || j
                        % }}	 d  |j                         D ]  \  }}t	        j                  ||        	 t        | j                        D ]  }t	        j                  |        y c c}w # |j                         D ]  \  }}t	        j                  ||        w xY wwrA   )
	threadingcurrent_threadmain_threadHANDLED_SIGNALSsignalhandle_exititemsreversedr2   raise_signal)r   sigoriginal_handlershandlercaptured_signals        r   rB   zServer.capture_signalsA  s      ##%Y-B-B-DD Sbb3S&--T5E5E"FFbb	, 1 7 7 9 ,Wc7+,
  ((>(>? 	1O0	1 c !2 7 7 9 ,Wc7+,s)   6C>(C C>#C 'A$C>0C;;C>c                    | j                   j                  |       | j                  r|t        j                  k(  rd| _        y d| _        y )NT)r2   rw   r/   r   SIGINTr0   )r   r   frames      r   r   zServer.handle_exitU  s9    %%c*v}} 4"DO#Dr    )r,   r   r"   r#   )r"   z
int | NonerA   )r:   zlist[socket.socket] | Noner"   r#   )r   zSequence[socket.SocketType]r"   r#   r!   )r   intr"   bool)r"   zGenerator[None, None, None])r   r   r   zFrameType | Noner"   r#   )r$   r%   r&   r   	functoolscached_propertyr4   r?   r<   rC   rU   r   rV   r   rW   r   
contextlibcontextmanagerrB   r   r(   r    r   r*   r*   8   su    	/ i i
e'U.[z!F6<+@'$ 1 1&$r    r*   )1
__future__r   rp   r   r   loggingrK   rs   r5   r   rc   r   r   r   collections.abcr   r   email.utilsr   typesr   typingr   r	   rQ   uvicorn._compatr
   uvicorn.configr   uvicorn.protocols.http.h11_implr   %uvicorn.protocols.http.httptools_implr   ,uvicorn.protocols.websockets.websockets_implr   3uvicorn.protocols.websockets.websockets_sansio_implr   )uvicorn.protocols.websockets.wsproto_implr   r   __annotations__r   SIGTERMr   SIGBREAK	getLoggerrS   r   r*   r(   r    r   <module>r      s    "     	     
   / "  +  ' !;GN\D&)::ZGJ[[^vvIyv MM
NN <<7))O			?	+	= 	=b$ b$r    