o
    m=8j8                     @   s   d dl Z d dlmZmZ ddlmZ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r8d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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TypeVar   )Handler
Middleware)HTTPMoveHTTPPermanentRedirect)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   ^/home/nk/hobo-godmode/plappi-mvp/.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   implL   s4   

z'normalize_path_middleware.<locals>.implr   r	   r   r
   )r!   r"   r#   r$   correct_configurationr7   r   r6   r   r   &   s
   
#"r   r   r   c                    s"   t dtdtdtf fdd}|S )Nr   r%   r   c                    s4   | j }|j} |_z|| I d H W ||_S ||_w )N)r   current_app)r   r%   r   prevr   r   r   r7   o   s   z&_fix_request_current_app.<locals>.implr8   )r   r7   r   r<   r   _fix_request_current_appn   s   	r=   )r/   typingr   r   typedefsr   r   web_exceptionsr   r   web_requestr	   web_responser
   web_urldispatcherr   __all__web_appr   r   strtupleboolr   r   typer   r=   r   r   r   r   <module>   s:    
H