File manager - Edit - /usr/lib/python3/dist-packages/oauthlib/oauth1/rfc5849/endpoints/__pycache__/resource.cpython-310.pyc
Back
o ���a� � @ sB d Z ddlZddlmZ ddlmZ e�e�ZG dd� de�Z dS ) z� oauthlib.oauth1.rfc5849.endpoints.resource ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ This module is an implementation of the resource protection provider logic of OAuth 1.0 RFC 5849. � N� )�errors� )�BaseEndpointc @ s e Zd ZdZ ddd�ZdS )�ResourceEndpointa! An endpoint responsible for protecting resources. Typical use is to instantiate with a request validator and invoke the ``validate_protected_resource_request`` in a decorator around a view function. If the request is valid, invoke and return the response of the view. If invalid create and return an error response directly from the decorator. See :doc:`/oauth1/validator` for details on which validator methods to implement for this endpoint. An example decorator:: from functools import wraps from your_validator import your_validator from oauthlib.oauth1 import ResourceEndpoint endpoint = ResourceEndpoint(your_validator) def require_oauth(realms=None): def decorator(f): @wraps(f) def wrapper(request, *args, **kwargs): v, r = provider.validate_protected_resource_request( request.url, http_method=request.method, body=request.data, headers=request.headers, realms=realms or []) if v: return f(*args, **kwargs) else: return abort(403) �GETNc C s� z | � ||||�}W n tjy Y dS w z| �|� | �|� W n tjy0 d|f Y S w |js8d|fS | j�|j�sCd|fS | jj|j |j |j||jd�sVd|fS | j�|j |�}|se| jj |_ | j�|j |j|�}|sv| jj|_| jj|j |j||j|d�} | �|�} ||jd<