3
e<              	   @   sz   d dl ZddlmZ ddlmZ ddl mZ edddd	d
dddgZG dd dZG dd de	Z
G dd dee
dZdS )    N   )current_app)request)ResponseReturnValuegetpostheadoptionsdeleteputtracepatchc               @   sp   e Zd ZU dZdZejeje  dZ	eje
 	g Zejej edddZeeejejejdddZdS )	Viewa  Alternative way to use view functions.  A subclass has to implement
    :meth:`dispatch_request` which is called with the view arguments from
    the URL routing system.  If :attr:`methods` is provided the methods
    do not have to be passed to the :meth:`~flask.Flask.add_url_rule`
    method explicitly::

        class MyView(View):
            methods = ['GET']

            def dispatch_request(self, name):
                return f"Hello {name}!"

        app.add_url_rule('/hello/<name>', view_func=MyView.as_view('myview'))

    When you want to decorate a pluggable view you will have to either do that
    when the view function is created (by wrapping the return value of
    :meth:`as_view`) or you can use the :attr:`decorators` attribute::

        class SecretView(View):
            methods = ['GET']
            decorators = [superuser_required]

            def dispatch_request(self):
                ...

    The decorators stored in the decorators list are applied one after another
    when the view function is created.  Note that you can *not* use the class
    based decorators since those would decorate the view class and not the
    generated view function!
    N)returnc             C   s
   t  dS )zSubclasses have to override this method to implement the
        actual view function code.  This method is called with all
        the arguments from the URL rule.
        N)NotImplementedError)self r   ,/tmp/pip-build-3irwxpxt/Flask/flask/views.pydispatch_request>   s    zView.dispatch_request)name
class_argsclass_kwargsr   c                sz   t jt jtd fdd| jrJ|_| j_x| jD ]}|q:W | _|_| j_| j_| j_| j	_	S )a  Converts the class into an actual view function that can be used
        with the routing system.  Internally this generates a function on the
        fly which will instantiate the :class:`View` on each request and call
        the :meth:`dispatch_request` method on it.

        The arguments passed to :meth:`as_view` are forwarded to the
        constructor of the class.
        )argskwargsr   c                 s   j  }tj|j| |S )N)
view_classr   ensure_syncr   )r   r   r   )r   r   viewr   r   r   R   s    zView.as_view.<locals>.view)
tAnyr   
decorators__name__
__module__r   __doc__methodsprovide_automatic_options)clsr   r   r   Z	decoratorr   )r   r   r   r   as_viewE   s    zView.as_view)r    r!   __qualname__r"   r#   r   OptionalListstrr$   boolr   Callabler   r   classmethodr   r&   r   r   r   r   r      s   

r   c                   s    e Zd ZdZ fddZ  ZS )MethodViewTypezYMetaclass for :class:`MethodView` that determines what methods the view
    defines.
    c                sx   t  j||| d|krtt }x$|D ]}t|dd r$|j|j q$W x$tD ]}t| |rJ|j|j	  qJW |rt|| _d S )Nr#   )
super__init__setgetattrupdater#   http_method_funcshasattraddupper)r%   r   basesdr#   basekey)	__class__r   r   r0   o   s    


zMethodViewType.__init__)r    r!   r'   r"   r0   __classcell__r   r   )r<   r   r.   j   s   r.   c               @   s&   e Zd ZdZejejedddZdS )
MethodViewa   A class-based view that dispatches request methods to the corresponding
    class methods. For example, if you implement a ``get`` method, it will be
    used to handle ``GET`` requests. ::

        class CounterAPI(MethodView):
            def get(self):
                return session.get('counter', 0)

            def post(self):
                session['counter'] = session.get('counter', 0) + 1
                return 'OK'

        app.add_url_rule('/counter', view_func=CounterAPI.as_view('counter'))
    )r   r   r   c             O   sX   t | tjj d }|d kr0tjdkr0t | dd }|d k	sHtdtjtj|||S )NHEADr   zUnimplemented method )r2   r   methodlowerAssertionErrorr   r   )r   r   r   methr   r   r   r      s
    zMethodView.dispatch_requestN)r    r!   r'   r"   r   r   r   r   r   r   r   r   r>      s   r>   )	metaclass)typingr   globalsr   r   r   	frozensetr4   r   typer.   r>   r   r   r   r   <module>   s   ]