o
    p)fN                     @  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 dd	lmZ dd
lmZ ejrAddlmZ G dd deZdS )    )annotationsN)	timedelta   )AppGroup)current_app)send_from_directory)	Blueprint)BlueprintSetupState)	_sentinel)Responsec                      sP   e Zd Zdddddddefd! fddZd"ddZd#ddZd$d%dd Z  ZS )&r   Nnamestrimport_namestatic_folderstr | os.PathLike[str] | Nonestatic_url_path
str | Nonetemplate_folder
url_prefix	subdomainurl_defaultsdict[str, t.Any] | None	root_path	cli_groupreturnNonec                   s4   t  |||||||||	|

 t | _| j| j_d S )N)super__init__r   clir   )selfr   r   r   r   r   r   r   r   r   r   	__class__ M/var/www/html/flask-app/venv/lib/python3.12/site-packages/flask/blueprints.pyr      s   zBlueprint.__init__filename
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)r   r$   valuer"   r"   r#   get_send_file_max_age7   s   

zBlueprint.get_send_file_max_ager   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   r   )r   r$   r-   r"   r"   r#   send_static_fileR   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.

        >   rr3   rtz)Resources can only be opened for reading.)
ValueErroropenospathjoinr   )r   r4   r5   r"   r"   r#   open_resourceh   s   zBlueprint.open_resource)r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   )r$   r   r   r%   )r$   r   r   r   )r3   )r4   r   r5   r   r   r6   )	__name__
__module____qualname__r
   r   r,   r2   r>   __classcell__r"   r"   r    r#   r      s    
$
r   )
__future__r   r;   typingr0   datetimer   r   r   globalsr   helpersr   sansio.blueprintsr   SansioBlueprintr	   sansio.scaffoldr
   TYPE_CHECKINGwrappersr   r"   r"   r"   r#   <module>   s    