o
    GEDi)                     @   s  d dl Z d dlmZmZmZmZmZmZ ddlm	Z	 ddl
mZmZ ddlmZ ddlmZ ddlmZ d	Zer>dd
lmZ edZdededeeef fddZdedefddZeee	gee f Zdddeddedededee def
ddZdddefdd ZdS )!    N)TYPE_CHECKING	AwaitableCallableTupleTypeTypeVar   )Handler)HTTPPermanentRedirect	_HTTPMove)Request)StreamResponse)SystemRoute)
middlewarenormalize_path_middleware)Application_Funcrequestpathreturnc                    sB   | j |d}| jj|I d H }||_|jd u rd|fS d| fS )N)rel_urlTF)cloneapprouterresolve_match_infohttp_exception)r   r   alt_request
match_info r   f/var/www/www-root/data/www/ovozai.pdev.uz/venv/lib/python3.10/site-packages/aiohttp/web_middlewares.py_check_request_resolves   s   
r!   fc                 C   s
   d| _ | S )Nr   )__middleware_version__)r"   r   r   r    r   !   s   r   TF)append_slashremove_slashmerge_slashesredirect_classr$   r%   r&   r'   c                    s>    o }|sJ dt dtdtdtf fdd}|S )a  Factory for producing a middleware that normalizes the path of a request.

    Normalizing means:
        - Add or remove a trailing slash to the path.
        - Double slashes are replaced by one.

    The middleware returns as soon as it finds a path that resolves
    correctly. The order if both merge and append/remove are enabled is
        1) merge slashes
        2) append/remove slash
        3) both merge slashes and append/remove slash.
    If the path resolves with at least one of those conditions, it will
    redirect to the new path.

    Only one of `append_slash` and `remove_slash` can be enabled. If both
    are `True` the factory will raise an assertion error

    If `append_slash` is `True` the middleware will append a slash when
    needed. If a resource is defined with trailing slash and the request
    comes without it, it will append it automatically.

    If `remove_slash` is `True`, `append_slash` must be `False`. When enabled
    the middleware will remove trailing slashes and redirect if the resource
    is defined

    If merge_slashes is True, merge multiple consecutive slashes in the
    path into one.
    z#Cannot both remove and append slashr   handlerr   c                    s0  t | jjtrg }d| jv r| jdd\}}d| }nd}| j}r.|tdd|  r=| j	
ds=||d  rN| j	
drN||d d  r^ r^|tdd|d  rrrrtdd|}||d d  |D ]}tdd|}t| |I d H \}} |r| j| qt|| I d H S )N?r    z//+/z^//+)
isinstancer   router   raw_pathsplitappendresubr   endswithr!   )r   r(   paths_to_checkr   querymerged_slashesresolvesr$   r&   r'   r%   r   r    implO   s4   

z'normalize_path_middleware.<locals>.implr   r   r	   r   )r$   r%   r&   r'   correct_configurationr:   r   r9   r    r   )   s
   
#"r   r   r   c                    s"   t dtdtdtf fdd}|S )Nr   r(   r   c                    s@   | j   || I d H W  d    S 1 sw   Y  d S )N)r   set_current_app)r   r(   r   r   r    r:   r   s   $z&_fix_request_current_app.<locals>.implr;   )r   r:   r   r>   r    _fix_request_current_appq   s   r?   )r2   typingr   r   r   r   r   r   typedefsr	   web_exceptionsr
   r   web_requestr   web_responser   web_urldispatcherr   __all__web_appr   r   strboolr!   r   _Middlewarer   r?   r   r   r   r    <module>   s<     
H