3
g                 @   s   d dl mZ d dlmZ d dlmZ d dlmZ d dlm	Z	 d dl
mZ d dlmZ d dlmZ d d	lmZmZ d d
lmZ G dd dZG dd deeZG dd deeZdS )    )urlparse)url2pathname)sync_to_async)settings)utils)serve)ASGIHandler)response_for_exception)WSGIHandlerget_path_info)Http404c               @   sL   e Zd ZdZdZdd Zdd Zdd Zd	d
 Zdd Z	dd Z
dd ZdS )StaticFilesHandlerMixinz8
    Common methods used by WSGI and ASGI handlers.
    Tc             C   s   d S )N )selfr   r   a/var/www/tester-filtro-web/env/lib/python3.6/site-packages/django/contrib/staticfiles/handlers.pyload_middleware   s    z'StaticFilesHandlerMixin.load_middlewarec             C   s   t j  tjS )N)r   Zcheck_settingsr   Z
STATIC_URL)r   r   r   r   get_base_url   s    z$StaticFilesHandlerMixin.get_base_urlc             C   s   |j | jd o| jd  S )z
        Check if the path should be handled. Ignore the path if:
        * the host is provided as part of the base_url
        * the request's path isn't under the media path (or equal)
              )
startswithbase_url)r   pathr   r   r   _should_handle    s    z&StaticFilesHandlerMixin._should_handlec             C   s   |t | jd d }t|S )zW
        Return the relative path to the media file on disk for the given URL.
        r   N)lenr   r   )r   urlZrelative_urlr   r   r   	file_path(   s    z!StaticFilesHandlerMixin.file_pathc             C   s   t || j|jddS )zServe the request path.T)Zinsecure)r   r   r   )r   requestr   r   r   r   /   s    zStaticFilesHandlerMixin.servec             C   s6   y
| j |S  tk
r0 } z
t||S d }~X nX d S )N)r   r   r	   )r   r   er   r   r   get_response3   s    
z$StaticFilesHandlerMixin.get_responsec                sR   yt | jdd|I d H S  tk
rL } zt tdd||I d H S d }~X nX d S )NF)Zthread_sensitive)r   r   r   r	   )r   r   r   r   r   r   get_response_async9   s    z*StaticFilesHandlerMixin.get_response_asyncN)__name__
__module____qualname____doc__Zhandles_filesr   r   r   r   r   r   r   r   r   r   r   r      s   r   c                   s,   e Zd ZdZ fddZ fddZ  ZS )StaticFilesHandlerz
    WSGI middleware that intercepts calls to the static files directory, as
    defined by the STATIC_URL setting, and serves those files.
    c                s"   || _ t| j | _t j  d S )N)applicationr   r   r   super__init__)r   r%   )	__class__r   r   r'   E   s    zStaticFilesHandler.__init__c                s(   | j t|s| j||S t j||S )N)r   r   r%   r&   __call__)r   environZstart_response)r(   r   r   r)   J   s    zStaticFilesHandler.__call__)r    r!   r"   r#   r'   r)   __classcell__r   r   )r(   r   r$   @   s   r$   c                   s(   e Zd ZdZdd Z fddZ  ZS )ASGIStaticFilesHandlerz
    ASGI application which wraps another and intercepts requests for static
    files, passing them off to Django's static file serving.
    c             C   s   || _ t| j | _d S )N)r%   r   r   r   )r   r%   r   r   r   r'   U   s    zASGIStaticFilesHandler.__init__c                sD   |d dkr0| j |d r0t j|||I d H S | j|||I d H S )Ntypehttpr   )r   r&   r)   r%   )r   ZscopeZreceivesend)r(   r   r   r)   Y   s    zASGIStaticFilesHandler.__call__)r    r!   r"   r#   r'   r)   r+   r   r   )r(   r   r,   P   s   r,   N)urllib.parser   urllib.requestr   Zasgiref.syncr   Zdjango.confr   Zdjango.contrib.staticfilesr   Z django.contrib.staticfiles.viewsr   Zdjango.core.handlers.asgir   Zdjango.core.handlers.exceptionr	   Zdjango.core.handlers.wsgir
   r   Zdjango.httpr   r   r$   r,   r   r   r   r   <module>   s   1