o
    "7h|%                     @   s  d Z ddlmZ ddlmZ dZG dd dZG dd deZG d	d
 d
eZG dd dZ	G dd dZ
G dd dZG dd deeZG dd dedZG dd deZG dd deZG dd deZG dd deZG dd deZG d d! d!eZG d"d# d#eZd$S )%z2
Provides a set of pluggable permission policies.
    )Http404)
exceptions)GETHEADOPTIONSc                   @   s4   e Zd Zdd Zdd Zdd Zdd Zd	d
 ZdS )OperationHolderMixinc                 C      t t| |S NOperandHolderANDselfother r   o/var/www/epreuve.sigeris.cm/public_html/epreuve/venv/lib/python3.10/site-packages/rest_framework/permissions.py__and__      zOperationHolderMixin.__and__c                 C   r   r	   r   ORr   r   r   r   __or__   r   zOperationHolderMixin.__or__c                 C      t t|| S r	   r
   r   r   r   r   __rand__   r   zOperationHolderMixin.__rand__c                 C   r   r	   r   r   r   r   r   __ror__   r   zOperationHolderMixin.__ror__c                 C   s
   t t| S r	   )SingleOperandHolderNOTr   r   r   r   
__invert__      
zOperationHolderMixin.__invert__N)__name__
__module____qualname__r   r   r   r   r   r   r   r   r   r      s    r   c                   @   s   e Zd Zdd Zdd ZdS )r   c                 C      || _ || _d S r	   )operator_class	op1_class)r   r#   r$   r   r   r   __init__      
zSingleOperandHolder.__init__c                 O   s   | j |i |}| |S r	   )r$   r#   )r   argskwargsop1r   r   r   __call__!   s   
zSingleOperandHolder.__call__N)r   r    r!   r%   r*   r   r   r   r   r      s    r   c                   @   s,   e Zd Zdd Zdd Zdd Zdd Zd	S )
r   c                 C   s   || _ || _|| _d S r	   )r#   r$   	op2_class)r   r#   r$   r+   r   r   r   r%   '   s   
zOperandHolder.__init__c                 O   s,   | j |i |}| j|i |}| ||S r	   )r$   r+   r#   )r   r'   r(   r)   op2r   r   r   r*   ,   s   zOperandHolder.__call__c                 C   s.   t |to| j|jko| j|jko| j|jkS r	   )
isinstancer   r#   r$   r+   r   r   r   r   __eq__1   s   



zOperandHolder.__eq__c                 C   s   t | j| j| jfS r	   )hashr#   r$   r+   r   r   r   r   __hash__9   s   zOperandHolder.__hash__N)r   r    r!   r%   r*   r.   r0   r   r   r   r   r   &   s
    r   c                   @   $   e Zd Zdd Zdd Zdd ZdS )r   c                 C   r"   r	   r)   r,   r   r)   r,   r   r   r   r%   >   r&   zAND.__init__c                 C   s   | j ||o| j||S r	   r)   has_permissionr,   r   requestviewr   r   r   r5   B      zAND.has_permissionc                 C   s    | j |||o| j|||S r	   )r)   has_object_permissionr,   r   r7   r8   objr   r   r   r:   H   s   zAND.has_object_permissionNr   r    r!   r%   r5   r:   r   r   r   r   r   =       r   c                   @   r1   )r   c                 C   r"   r	   r2   r3   r   r   r   r%   P   r&   zOR.__init__c                 C   s   | j ||p| j||S r	   r4   r6   r   r   r   r5   T   r9   zOR.has_permissionc                 C   s<   | j ||o| j |||p| j||o| j|||S r	   )r)   r5   r:   r,   r;   r   r   r   r:   Z   s   zOR.has_object_permissionNr=   r   r   r   r   r   O   r>   r   c                   @   r1   )r   c                 C   s
   || _ d S r	   )r)   )r   r)   r   r   r   r%   e   r   zNOT.__init__c                 C   s   | j || S r	   )r)   r5   r6   r   r   r   r5   h   s   zNOT.has_permissionc                 C   s   | j ||| S r	   )r)   r:   r;   r   r   r   r:   k      zNOT.has_object_permissionNr=   r   r   r   r   r   d   s    r   c                   @   s   e Zd ZdS )BasePermissionMetaclassN)r   r    r!   r   r   r   r   r@   o   s    r@   c                   @   s    e Zd ZdZdd Zdd ZdS )BasePermissionzH
    A base class from which all permission classes should inherit.
    c                 C      dS zL
        Return `True` if permission is granted, `False` otherwise.
        Tr   r6   r   r   r   r5   x      zBasePermission.has_permissionc                 C   rB   rC   r   r;   r   r   r   r:   ~   rD   z$BasePermission.has_object_permissionN)r   r    r!   __doc__r5   r:   r   r   r   r   rA   s   s    rA   )	metaclassc                   @      e Zd ZdZdd ZdS )AllowAnyz
    Allow any access.
    This isn't strictly required, since you could use an empty
    permission_classes list, but it's useful because it makes the intention
    more explicit.
    c                 C   rB   )NTr   r6   r   r   r   r5      s   zAllowAny.has_permissionNr   r    r!   rE   r5   r   r   r   r   rH      s    rH   c                   @   rG   )IsAuthenticatedz4
    Allows access only to authenticated users.
    c                 C      t |jo|jjS r	   )booluseris_authenticatedr6   r   r   r   r5      r?   zIsAuthenticated.has_permissionNrI   r   r   r   r   rJ          rJ   c                   @   rG   )IsAdminUserz,
    Allows access only to admin users.
    c                 C   rK   r	   )rL   rM   is_staffr6   r   r   r   r5      r?   zIsAdminUser.has_permissionNrI   r   r   r   r   rP      rO   rP   c                   @   rG   )IsAuthenticatedOrReadOnlyzL
    The request is authenticated as a user, or is a read-only request.
    c                 C   s   t |jtv p|jo|jjS r	   )rL   methodSAFE_METHODSrM   rN   r6   r   r   r   r5      s
   
z(IsAuthenticatedOrReadOnly.has_permissionNrI   r   r   r   r   rR      rO   rR   c                   @   sH   e Zd ZdZg g g dgdgdgdgdZdZdd Zd	d
 Zdd ZdS )DjangoModelPermissionsa}  
    The request is authenticated using `django.contrib.auth` permissions.
    See: https://docs.djangoproject.com/en/dev/topics/auth/#permissions

    It ensures that the user is authenticated, and has the appropriate
    `add`/`change`/`delete` permissions on the model.

    This permission can only be applied against view classes that
    provide a `.queryset` attribute.
     %(app_label)s.add_%(model_name)s#%(app_label)s.change_%(model_name)s#%(app_label)s.delete_%(model_name)sr   r   r   POSTPUTPATCHDELETETc                    >   |j j|j jd || jvrt| fdd| j| D S )z
        Given a model and an HTTP method, return the list of permission
        codes that the user is required to have.
        	app_label
model_namec                       g | ]}|  qS r   r   .0permr(   r   r   
<listcomp>       zCDjangoModelPermissions.get_required_permissions.<locals>.<listcomp>_metar`   ra   	perms_mapr   MethodNotAllowedr   rS   	model_clsr   rf   r   get_required_permissions   s   

z/DjangoModelPermissions.get_required_permissionsc                 C   sb   t |dst|dd d usJ d| jjt |dr.| }|d us,J d|jj|S |jS )Nget_querysetquerysetz[Cannot apply {} on a view that does not set `.queryset` or have a `.get_queryset()` method.z{}.get_queryset() returned None)hasattrgetattrformat	__class__r   rp   rq   )r   r8   rq   r   r   r   	_queryset   s   



z DjangoModelPermissions._querysetc                 C   sN   |j r
|j js| jrdS t|ddrdS | |}| |j|j}|j |S )NF_ignore_model_permissionsT)	rM   rN   authenticated_users_onlyrs   rv   ro   rS   model	has_perms)r   r7   r8   rq   permsr   r   r   r5      s   
z%DjangoModelPermissions.has_permissionN)	r   r    r!   rE   rk   rx   ro   rv   r5   r   r   r   r   rU      s    
rU   c                   @   s   e Zd ZdZdZdS )$DjangoModelPermissionsOrAnonReadOnlyzj
    Similar to DjangoModelPermissions, except that anonymous users are
    allowed read-only access.
    FN)r   r    r!   rE   rx   r   r   r   r   r|      s    r|   c                   @   s<   e Zd ZdZg g g dgdgdgdgdZdd Zdd	 Zd
S )DjangoObjectPermissionsa  
    The request is authenticated using Django's object-level permissions.
    It requires an object-permissions-enabled backend, such as Django Guardian.

    It ensures that the user is authenticated, and has the appropriate
    `add`/`change`/`delete` permissions on the object using .has_perms.

    This permission can only be applied against view classes that
    provide a `.queryset` attribute.
    rV   rW   rX   rY   c                    r^   )Nr_   c                    rb   r   r   rc   rf   r   r   rg     rh   zKDjangoObjectPermissions.get_required_object_permissions.<locals>.<listcomp>ri   rm   r   rf   r   get_required_object_permissions  s   

z7DjangoObjectPermissions.get_required_object_permissionsc           	      C   sb   |  |}|j}|j}| |j|}|||s/|jtv rt| d|}|||s-tdS dS )Nr   FT)rv   ry   rM   r~   rS   rz   rT   r   )	r   r7   r8   r<   rq   rn   rM   r{   
read_permsr   r   r   r:   !  s   

z-DjangoObjectPermissions.has_object_permissionN)r   r    r!   rE   rk   r~   r:   r   r   r   r   r}     s    
r}   N)rE   django.httpr   rest_frameworkr   rT   r   r   r   r   r   r   typer@   rA   rH   rJ   rP   rR   rU   r|   r}   r   r   r   r   <module>   s&    
		I