o
    e                     @   s~   d 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
mZ ddlmZ ddlmZ G d	d
 d
ZG dd deZdS )aL  
The metadata API is used to allow customization of how `OPTIONS` requests
are handled. We currently provide a single default implementation that returns
some fairly ad-hoc information about the view.

Future implementations might use JSON schema or other definitions in order
to return this information in a more standardized way.
    )OrderedDict)PermissionDenied)Http404	force_str)
exceptionsserializers)clone_request)ClassLookupDictc                   @   s   e Zd Zdd ZdS )BaseMetadatac                 C   s   t d)zx
        Return a dictionary of metadata about the view.
        Used to return responses for OPTIONS requests.
        z).determine_metadata() must be overridden.)NotImplementedError)selfrequestview r   J/var/www/html/venv/lib/python3.10/site-packages/rest_framework/metadata.pydetermine_metadata   s   zBaseMetadata.determine_metadataN)__name__
__module____qualname__r   r   r   r   r   r      s    r   c                
   @   s   e Zd ZdZei ejdejdejdej	dej
dejdejdejdejd	ejd
ejdejdejdejdejdejdejdejdejdejdejdiZdd Zdd Zdd Zdd ZdS )SimpleMetadataz
    This is the default metadata implementation.
    It returns an ad-hoc set of information about the view.
    There are not any formalized standards for `OPTIONS` responses
    for us to base this on.
    fieldbooleanstringurlemailregexslugintegerfloatdecimaldatedatetimetimechoicezmultiple choicezfile uploadzimage uploadlistznested objectc                 C   sl   t  }| |d< | |d< dd |jD |d< dd |jD |d< t|dr4| ||}|r4||d	< |S )
Nnamedescriptionc                 S      g | ]}|j qS r   
media_type).0rendererr   r   r   
<listcomp>@       z5SimpleMetadata.determine_metadata.<locals>.<listcomp>rendersc                 S   r(   r   r)   )r+   parserr   r   r   r-   A   r.   parsesget_serializeractions)r   get_view_nameget_view_descriptionrenderer_classesparser_classeshasattrdetermine_actions)r   r   r   metadatar3   r   r   r   r   <   s   
z!SimpleMetadata.determine_metadatac                 C   s   i }ddht |j@ D ]D}t|||_z8zt|dr ||j |dkr-t|dr-|  W n tjt	t
fy;   Y nw | }| |||< W ||_q||_w |S )z
        For generic class based views we return information about
        the fields that are accepted for 'PUT' and 'POST' methods.
        PUTPOSTcheck_permissions
get_object)setallowed_methodsr	   r   r8   r=   r>   r   APIExceptionr   r   r2   get_serializer_info)r   r   r   r3   method
serializerr   r   r   r9   H   s"   
z SimpleMetadata.determine_actionsc                    s,   t |dr|j}t fdd|j D S )zn
        Given an instance of a serializer, return a dictionary of metadata
        about its fields.
        childc                    s*   g | ]\}}t |tjs| |fqS r   )
isinstancer   HiddenFieldget_field_info)r+   
field_namer   r   r   r   r-   l   s    
z6SimpleMetadata.get_serializer_info.<locals>.<listcomp>)r8   rE   r   fieldsitems)r   rD   r   rJ   r   rB   c   s
   
z"SimpleMetadata.get_serializer_infoc                 C   s   t  }| j| |d< t|dd|d< g d}|D ]}t||d}|dur0|dkr0t|dd||< qt|d	dr@| |j|d	< nt|d
drM| ||d< |dslt|t	j
t	jfslt|drldd |j D |d< |S )zl
        Given an instance of a serializer field, return a dictionary
        of metadata about it.
        typerequiredF)	read_onlylabel	help_text
min_length
max_length	min_value	max_valueN Tstrings_onlyrE   rK   childrenrO   choicesc                 S   s"   g | ]\}}|t |d ddqS )TrW   )valuedisplay_namer   )r+   choice_valuechoice_namer   r   r   r-      s    
z1SimpleMetadata.get_field_info.<locals>.<listcomp>)r   label_lookupgetattrr   rH   rE   rB   getrF   r   RelatedFieldManyRelatedFieldr8   rZ   rL   )r   r   
field_infoattrsattrr[   r   r   r   rH   r   s,   

zSimpleMetadata.get_field_infoN) r   r   r   __doc__r
   r   FieldBooleanField	CharField	UUIDFieldURLField
EmailField
RegexField	SlugFieldIntegerField
FloatFieldDecimalField	DateFieldDateTimeField	TimeFieldChoiceFieldMultipleChoiceField	FileField
ImageField	ListField	DictField
Serializerr_   r   r9   rB   rH   r   r   r   r   r      s\    	
r   N)rg   collectionsr   django.core.exceptionsr   django.httpr   django.utils.encodingr   rest_frameworkr   r   rest_framework.requestr	   "rest_framework.utils.field_mappingr
   r   r   r   r   r   r   <module>   s    	