o
    q>e9                     @  s~   d dl mZ d dlZd dl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 ejr5dd	lmZ G d
d deZdS )    )annotationsN)	timedelta   )current_app)send_from_directory)	Blueprint)BlueprintSetupState)Responsec                   @  s,   e Zd ZdddZdd	d
ZddddZdS )r   filename
str | Nonereturn
int | Nonec                 C  s0   t jd }|du rdS t|trt| S |S )an  Used by :func:`send_file` to determine the ``max_age`` cache
        value for a given file path if it wasn't passed.

        By default, this returns :data:`SEND_FILE_MAX_AGE_DEFAULT` from
        the configuration of :data:`~flask.current_app`. This defaults
        to ``None``, which tells the browser to use conditional requests
        instead of a timed cache, which is usually preferable.

        Note this is a duplicate of the same method in the Flask
        class.

        .. versionchanged:: 2.0
            The default configuration is ``None`` instead of 12 hours.

        .. versionadded:: 0.9
        SEND_FILE_MAX_AGE_DEFAULTN)r   config
isinstancer   inttotal_seconds)selfr
   value r   Q/var/www/bmteknikk.ddns.net/venv/lib/python3.10/site-packages/flask/blueprints.pyget_send_file_max_age   s   

zBlueprint.get_send_file_max_agestrr	   c                 C  s0   | j std| |}ttt| j||dS )aA  The view function used to serve files from
        :attr:`static_folder`. A route is automatically registered for
        this view at :attr:`static_url_path` if :attr:`static_folder` is
        set.

        Note this is a duplicate of the same method in the Flask
        class.

        .. versionadded:: 0.5

        z2'static_folder' must be set to serve static_files.)max_age)has_static_folderRuntimeErrorr   r   tcastr   static_folder)r   r
   r   r   r   r   send_static_file,   s   
zBlueprint.send_static_filerbresourcemodet.IO[t.AnyStr]c                 C  s&   |dvrt dttj| j||S )a  Open a resource file relative to :attr:`root_path` for
        reading.

        For example, if the file ``schema.sql`` is next to the file
        ``app.py`` where the ``Flask`` app is defined, it can be opened
        with:

        .. code-block:: python

            with app.open_resource("schema.sql") as f:
                conn.executescript(f.read())

        :param resource: Path to the resource relative to
            :attr:`root_path`.
        :param mode: Open the file in this mode. Only reading is
            supported, valid values are "r" (or "rt") and "rb".

        Note this is a duplicate of the same method in the Flask
        class.

        >   rr    rtz)Resources can only be opened for reading.)
ValueErroropenospathjoin	root_path)r   r!   r"   r   r   r   open_resourceB   s   zBlueprint.open_resourceN)r
   r   r   r   )r
   r   r   r	   )r    )r!   r   r"   r   r   r#   )__name__
__module____qualname__r   r   r,   r   r   r   r   r      s    

r   )
__future__r   r(   typingr   datetimer   globalsr   helpersr   sansio.blueprintsr   SansioBlueprintr   TYPE_CHECKINGwrappersr	   r   r   r   r   <module>   s    