HEX
Server: Apache
System: Linux pdx1-shared-a1-38 6.6.104-grsec-jammy+ #3 SMP Tue Sep 16 00:28:11 UTC 2025 x86_64
User: mmickelson (3396398)
PHP: 8.1.31
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/django/db/models/fields/__pycache__/related.cpython-310.pyc
o

3�a2�@s�ddlZddlZddlmZddlmZddlmZddlmZm	Z	ddl
mZmZddl
mZmZddlmZdd	lmZdd
lmZddlmZmZmZddlmZdd
lmZddlmZddl m!Z"ddl#m$Z$ddl%m&Z&ddl'm(Z(m)Z)m*Z*m+Z+m,Z,m-Z-ddl.m/Z/m0Z0m1Z1m2Z2m3Z3m4Z4m5Z5ddl6m7Z7m8Z8m9Z9m:Z:dZ;dd�Z<dd�Z=Gdd�de&e$�Z>Gdd�de>�Z?e?�@e2�e?�@e/�e?�@e4�e?�@e0�e?�@e1�e?�@e5�e?�@e3�Gdd �d e?�ZAGd!d"�d"eA�ZBd#d$�ZCGd%d&�d&e>�ZDdS)'�N)�partial)�forms)�apps)�SettingsReference�settings)�checks�
exceptions)�
connection�router)�utils)�Q)�
LOOKUP_SEP)�CASCADE�SET_DEFAULT�SET_NULL)�PathInfo��make_model_tuple)�cached_property)�gettext_lazy�)�Field)�FieldCacheMixin)�ForeignKeyDeferredAttribute�ForwardManyToOneDescriptor�ForwardOneToOneDescriptor�ManyToManyDescriptor�ReverseManyToOneDescriptor�ReverseOneToOneDescriptor)�RelatedExact�RelatedGreaterThan�RelatedGreaterThanOrEqual�	RelatedIn�
RelatedIsNull�RelatedLessThan�RelatedLessThanOrEqual)�ForeignObjectRel�
ManyToManyRel�ManyToOneRel�OneToOneRel�selfcCs2|tkr|}t|t�rd|vrd|jj|f}|S)a�
    Transform relation into a model or fully-qualified model string of the form
    "app_label.ModelName", relative to scope_model.

    The relation argument can be:
      * RECURSIVE_RELATIONSHIP_CONSTANT, i.e. the string "self", in which case
        the model argument will be returned.
      * A bare model name without an app_label, in which case scope_model's
        app_label will be prepended.
      * An "app_label.ModelName" string.
      * A model class, which will be returned unchanged.
    �.�%s.%s)�RECURSIVE_RELATIONSHIP_CONSTANT�
isinstance�str�_meta�	app_label)�scope_model�relation�r4�A/usr/lib/python3/dist-packages/django/db/models/fields/related.py�resolve_relation%s
r6csL�g�fdd�|D�}dd�|D�}�jj}|jt|fi|��g|�R�S)a�
    Schedule `function` to be called once `model` and all `related_models`
    have been imported and registered with the app registry. `function` will
    be called with the newly-loaded model classes as its positional arguments,
    plus any optional keyword arguments.

    The `model` argument must be a model class. Each subsequent positional
    argument is another model, or a reference to another model - see
    `resolve_relation()` for the various forms these may take. Any relative
    references will be resolved relative to `model`.

    This is a convenience wrapper for `Apps.lazy_model_operation` - the app
    registry model used is the one found in `model._meta.apps`.
    csg|]}t�|��qSr4)r6)�.0�rel��modelr4r5�
<listcomp>Msz*lazy_related_operation.<locals>.<listcomp>css�|]}t|�VqdS�Nr)r7�mr4r4r5�	<genexpr>N��z)lazy_related_operation.<locals>.<genexpr>)r0r�lazy_model_operationr)�functionr:�related_models�kwargs�models�
model_keysrr4r9r5�lazy_related_operation>srFcs�eZdZdZdZdZdZdZedd��Z	�fdd�Z
dd�Zd	d
�Zdd�Z
d
d�Zdd�Zdd�Zd+�fdd�	Z�fdd�Zdd�Zdd�Zedd��Zdd�Zdd �Zd!d"�Z�fd#d$�Zd%d&�Zed'd(��Zd)d*�Z�ZS),�RelatedFieldz3Base class that all relational fields inherit from.FcCst��|jjSr<)r�check_models_ready�remote_fieldr:�r*r4r4r5�
related_model\szRelatedField.related_modelcs>gt�jdi|���|���|���|���|���|���S�Nr4)�super�check�_check_related_name_is_valid�"_check_related_query_name_is_valid�_check_relation_model_exists�#_check_referencing_to_swapped_model�_check_clashes�r*rC��	__class__r4r5rNbs������zRelatedField.checkcCslddl}|jj}|durgS|�|�o|��}|s4|�d�s4tjd|jj|jj	j
|jfd|dd�gSgS)Nr�+z5The name '%s' is invalid related_name for field %s.%sz@Related name must be a valid Python identifier or end with a '+'zfields.E306��hint�obj�id)�keywordrI�related_name�	iskeyword�isidentifier�endswithr�Errorr:r0�object_name�name)r*r\r]�is_valid_idr4r4r5rOls$����
z)RelatedField._check_related_name_is_validcCsl|j��rgS|��}g}|�d�r |�tjd|d|dd��t|vr4|�tjd|tfd|dd��|S)N�_z8Reverse query name '%s' must not end with an underscore.zKAdd or change a related_name or related_query_name argument for this field.zfields.E308rXz.Reverse query name '%s' must not contain '%s'.zfields.E309)rI�	is_hidden�related_query_namer`�appendrrar
)r*�rel_query_name�errorsr4r4r5rPs6

���
���
z/RelatedField._check_related_query_name_is_validcCsh|jj|jj��v}t|jjt�}|r|jjn|jjjj}|r2|s'|jjjj	s2t
jd||dd�gSgS)NzXField defines a relation with model '%s', which is either not installed, or is abstract.zfields.E300�rZr[)rIr:�optsr�
get_modelsr.r/r0rb�swappedrra)r*�rel_is_missing�
rel_is_string�
model_namer4r4r5rQ�s���z)RelatedField._check_relation_model_existscCs^|jj|jj��vr-t|jjt�s-|jjjjr-t	j
d|jjjjd|jjjj|dd�gSgS)NzIField defines a relation with the model '%s', which has been swapped out.z.Update the relation to point at 'settings.%s'.zfields.E301rX)
rIr:rlrrmr.r/r0rnrra�label�	swappablerJr4r4r5rR�s�
�
���	z0RelatedField._check_referencing_to_swapped_modelc	s�ddlm}g}�jj}t�jj|�sgS�jjj}�j��}�j��}���}d|j	�j
f}|j|j}	|	D]>}
d|j	|
j
f}|s]|
j
|kr]|�
tjd||fd||f�dd��|
j
|krv|�
tjd||fd||f�d	d��q8�fd
d�|jD�}	|	D]C}
d|
jjj	|
jj
f}|s�|
��|kr�|�
tjd||fd
||f�dd��|
��|kr�|�
tjd||fd
||f�dd��q�|S)z.Check accessor and reverse query name clashes.r)�	ModelBaser,z7Reverse accessor for '%s' clashes with field name '%s'.zZRename field '%s', or add/change a related_name argument to the definition for field '%s'.zfields.E302rXz9Reverse query name for '%s' clashes with field name '%s'.zfields.E303c3s�|]
}|j�ur|VqdSr<��field)r7�rrJr4r5r>�s�z.RelatedField._check_clashes.<locals>.<genexpr>zAReverse accessor for '%s' clashes with reverse accessor for '%s'.zIAdd or change a related_name argument to the definition for '%s' or '%s'.zfields.E304zEReverse query name for '%s' clashes with reverse query name for '%s'.zfields.E305)�django.db.models.basertr:r0r.rIrf�get_accessor_namergrrrc�fields�many_to_manyrhrra�related_objectsrKrv)r*rtrjrl�rel_opts�
rel_is_hidden�rel_nameri�
field_name�potential_clashes�clash_field�
clash_namer4rJr5rS�s�



���


����
�
���
�����zRelatedField._check_clashescC�dSr<r4�r*r	r4r4r5�db_type�zRelatedField.db_typecs�t�j||fd|i|��|j|_|jjsc|jjr|jj}n|jj}|r;||j�	�|jj
�	�|jj�	�d�}||j_|jjrS|jj|j�	�|jj�	�d�}||j_dd�}t
|||jj|d�dSdS)N�private_only)�classrqr1)r�r1cSs||j_|�||�dSr<)rIr:�do_related_class)r:�relatedrvr4r4r5�resolve_related_class;sz?RelatedField.contribute_to_class.<locals>.resolve_related_classru)rM�contribute_to_classr0rl�abstractrIr]�default_related_name�__name__�lowerrqr1rgrFr:)r*�clsrcr�rCr]rgr�rUr4r5r�!s,


�
��z RelatedField.contribute_to_classcsbt���\}}}}|jjr|jj|d<|jjdur|jj|d<|jjdur+|jj|d<||||fS)N�limit_choices_tor]rg)rM�deconstructrIr�r]rg�r*rc�path�argsrCrUr4r5r�@szRelatedField.deconstructcs��fdd��jD�S)a>
        Return the keyword arguments that when supplied to
        self.model.object.filter(), would select all instances related through
        this field to the remote obj. This is used to build the querysets
        returned by related descriptors. obj is an instance of
        self.related_field.model.
        cs*i|]\}}d�j|jft�|j��qS)z%s__%s)rc�getattr�attname)r7re�rh_field�rZr*r4r5�
<dictcomp>Rs��z;RelatedField.get_forward_related_filter.<locals>.<dictcomp>��related_fields�r*rZr4r�r5�get_forward_related_filterJs�z'RelatedField.get_forward_related_filtercsX�fdd�|jD�}|���}tdi|��}t|t�r$|tdi|��@S|r*||@S|S)a%
        Complement to get_forward_related_filter(). Return the keyword
        arguments that when passed to self.related_field.model.object.filter()
        select all instances of self.related_field.model related through
        this field to obj. obj is an instance of self.model.
        cs i|]\}}|jt�|j��qSr4)r�r�)r7�lh_fieldr��rZr4r5r�^s��z;RelatedField.get_reverse_related_filter.<locals>.<dictcomp>Nr4)r��get_extra_descriptor_filterrr.�dict)r*rZ�base_filter�descriptor_filter�base_qr4r�r5�get_reverse_related_filterWs
�

z'RelatedField.get_reverse_related_filtercCs8|jrt|jjt�r|jj}n|jjjj}t�|�SdS)z�
        Get the setting that this is powered from for swapping, or None
        if it's not swapped in / marked with swappable=False.
        N)	rsr.rIr:r/r0rrr�get_swappable_settings_name)r*�	to_stringr4r4r5�swappable_settingjs

zRelatedField.swappable_settingcCsL|jp|jjjjd|jjjjj|_|jdur|jjjj|_|j��dS)Nre)rcrIr:r0rq�pk�verbose_name�set_field_namerJr4r4r5�set_attributes_from_relys�
z$RelatedField.set_attributes_from_relcCs|��|�||j�dSr<)r��contribute_to_related_classrI)r*�otherr�r4r4r5r��szRelatedField.do_related_classcCst|jj�r|j��S|jjS)z�
        Return ``limit_choices_to`` for this model field.

        If it is a callable, it will be invoked and the result will be
        returned.
        )�callablerIr�rJr4r4r5�get_limit_choices_to�s
z!RelatedField.get_limit_choices_tocsBi}t|jd�r|jj}|�d|i�|�|�t�jdi|��S)z�
        Pass ``limit_choices_to`` to the field being constructed.

        Only passes it if there is a type that supports related fields.
        This is a similar strategy used to pass the ``queryset`` to the field
        being constructed.
        �get_related_fieldr�Nr4)�hasattrrIr��updaterM�	formfield)r*rC�defaultsr�rUr4r5r��s�
zRelatedField.formfieldcCs|jjp|jjp|jjS)zu
        Define the name that can be used to identify this related object in a
        table-spanning query.
        )rIrgr]rlrqrJr4r4r5rg�szRelatedField.related_query_namecCs,|��dj}t|�dkrt�d��|dS)z�
        When filtering against this relation, return the field on the remote
        model against which the filtering should happen.
        ���rzSThe relation has multiple target fields, but only single target field was asked forr)�
get_path_info�
target_fields�lenr�
FieldError)r*r�r4r4r5�target_field�s�zRelatedField.target_fieldcCs|jSr<�rcrJr4r4r5�get_cache_name�szRelatedField.get_cache_name�F)r��
__module__�__qualname__�__doc__�one_to_many�
one_to_oner{�many_to_onerrKrNrOrPrQrRrSr�r�r�r�r��propertyr�r�r�r�r�rgr�r��
__classcell__r4r4rUr5rGSs:

b


	
rGcs4eZdZdZdZdZdZdZdZe	Z
eZe
Z			d4�fdd�	Z�fdd�Zd	d
�Zdd�Z�fd
d�Zdd�Zedd��Zedd��Zedd��Zedd��Zdd�Zdd�Zedd��Z�fdd �Zd5d!d"�Zd#d$�Z d%d&�Z!d'd(�Z"d6d)d*�Z#d6d+d,�Z$e%e&j'dd-�d.d/���Z(d5�fd0d1�	Z)d2d3�Z*�Z+S)7�
ForeignObjectzS
    Abstraction of the ForeignKey relation to support multi-column relations.
    FTNc	sL|dur|j||||||	|d�}t�jdd|i|��||_||_|
|_dS)N�r]rgr��parent_link�	on_deleter8r4)�	rel_classrM�__init__�from_fields�	to_fieldsrs)r*�tor�r�r�r8r]rgr�r�rsrCrUr4r5r��s�	
zForeignObject.__init__c�&gt�jdi|���|���|���SrL)rMrN�_check_to_fields_exist�_check_unique_targetrTrUr4r5rN�����zForeignObject.checkcCszt|jjt�r	gSg}|jD],}|r:z
|jjj�|�Wqtjy9|�	t
jd||jjjjf|dd��Yqwq|S)Nz:The to_field '%s' doesn't exist on the related model '%s'.zfields.E312rk)
r.rIr:r/r�r0�	get_fieldr�FieldDoesNotExistrhrrarr)r*rj�to_fieldr4r4r5r��s(
�����
z$ForeignObject._check_to_fields_existcsHt|jjt�}|s|jsgSz|jWntjygYSw|js%gSdd�|jjj�	�D�}|�
dd�|jjjjD��|�
dd�|jjjjD��dd�|jD��t
�fdd�|D��}|s�t|j�dkr�d	�d
d�|jD��}|jjj}tjd||fd|d
d�gS|s�|jdj}|jjj}tjd||fd|dd�gSgS)NcSs$h|]}t|dd�rt|jg��qS)�uniqueF)r��	frozensetrc�r7�fr4r4r5�	<setcomp>
s
�
�z5ForeignObject._check_unique_target.<locals>.<setcomp>cSsh|]}t|��qSr4)r�)r7�utr4r4r5r�s��cSsh|]}t|j��qSr4)r�rz)r7�ucr4r4r5r�s��cSsh|]}|j�qSr4r�r�r4r4r5r��c3s�|]}|�kVqdSr<r4)r7�u��foreign_fieldsr4r5r>r?z5ForeignObject._check_unique_target.<locals>.<genexpr>r�, css�|]}d|jVqdS)z'%s'Nr�)r7�	rel_fieldr4r4r5r>s�

�z3No subset of the fields %s on model '%s' is unique.z�Mark a single field as unique=True or add a set of fields to a unique constraint (via unique_together or a UniqueConstraint (without condition) in the model Meta.constraints).zfields.E310rXrzA'%s.%s' must be unique because it is referenced by a foreign key.zjAdd unique=True to this field or add a UniqueConstraint (without condition) in the model Meta.constraints.zfields.E311)r.rIr:r/�requires_unique_target�foreign_related_fieldsrr�r0�
get_fieldsr��unique_together�total_unique_constraints�anyr��joinr�rrarc)r*rp�unique_foreign_fields�has_unique_constraint�field_combinationrqr�r4r�r5r��s`

��

�

�
�
���
���z"ForeignObject._check_unique_targetcst���\}}}}|jj|d<|j|d<|j|d<|jjr#|jj|d<t|jjt	�rMd|jjvrD|jj�
d�\}}d||��f|d<n|jj��|d<n|jjjj
|d<|j}|dur~t|dd�ru|dj|krutd	|dj|f��t|d|�|d<||||fS)
Nr�r�r�r�r+r,r��setting_namezoCannot deconstruct a ForeignKey pointing to a model that is swapped in place of more than one model (%s and %s))rMr�rIr�r�r�r�r.r:r/�splitr�r0�label_lowerr�r�r��
ValueErrorr)r*rcr�r�rCr1rqr�rUr4r5r�@s4

���zForeignObject.deconstructcCs�|jr
t|j�t|j�krtd��t|jjt�r td|jj��g}tt|j��D]1}|j|}|j|}|t	kr;|n|j
�|�}|durK|jjjj
n|jjj�|�}|�||f�q)|S)NzBForeign Object from and to fields must be the same non-zero lengthz#Related model %r cannot be resolved)r�r�r�r�r.rIr:r/�ranger-rlr�r0r�rh)r*r��index�from_field_name�
to_field_name�
from_fieldr�r4r4r5�resolve_related_fieldscs"

�
��z$ForeignObject.resolve_related_fieldscCs|��Sr<)r�rJr4r4r5r�vszForeignObject.related_fieldscCsdd�|jD�S)NcSsg|]\}}||f�qSr4r4�r7�	lhs_field�	rhs_fieldr4r4r5r;|sz8ForeignObject.reverse_related_fields.<locals>.<listcomp>r�rJr4r4r5�reverse_related_fieldszsz$ForeignObject.reverse_related_fieldscC�tdd�|jD��S)Ncss�|]\}}|VqdSr<r4r�r4r4r5r>�r?z5ForeignObject.local_related_fields.<locals>.<genexpr>��tupler�rJr4r4r5�local_related_fields~�z"ForeignObject.local_related_fieldscCr�)Ncss�|]	\}}|r|VqdSr<r4r�r4r4r5r>�s�z7ForeignObject.foreign_related_fields.<locals>.<genexpr>rrJr4r4r5r��rz$ForeignObject.foreign_related_fieldscC�|�||j�Sr<)�get_instance_value_for_fieldsr�r*�instancer4r4r5�get_local_related_value��z%ForeignObject.get_local_related_valuecCrr<)rr�rr4r4r5�get_foreign_related_value�r	z'ForeignObject.get_foreign_related_valuecCsbg}|j}|D]%}|jr#|�|j�}|r|js|jjjr#|�|j�q|�t||j��qt	|�Sr<)
r0�primary_key�get_ancestor_linkr:r�rhr�r�r�r)rrz�retrlrv�possible_parent_linkr4r4r5r�s��z+ForeignObject.get_instance_value_for_fieldscst���\}}|dfSr<)rM�get_attname_column�r*r��columnrUr4r5r�sz ForeignObject.get_attname_columncCs"|r|jn|j}tdd�|D��S)Ncss �|]\}}|j|jfVqdSr<)rr�r4r4r5r>�s�z4ForeignObject.get_joining_columns.<locals>.<genexpr>)r�r�r)r*�reverse_join�sourcer4r4r5�get_joining_columns�sz!ForeignObject.get_joining_columnscCs|jdd�S)NT)r)rrJr4r4r5�get_reverse_joining_columns��z)ForeignObject.get_reverse_joining_columnscCsiS)a�
        Return an extra filter condition for related object fetching when
        user does 'instance.fieldname', that is the extra filter is used in
        the descriptor of the field.

        The filter should be either a dict usable in .filter(**kwargs) call or
        a Q-object. The condition will be ANDed together with the relation's
        joining columns.

        A parallel method is get_extra_restriction() which is used in
        JOIN and subquery conditions.
        r4rr4r4r5r��s
z)ForeignObject.get_extra_descriptor_filtercCsdS)a�
        Return a pair condition used for joining and subquery pushdown. The
        condition is something that responds to as_sql(compiler, connection)
        method.

        Note that currently referring both the 'alias' and 'related_alias'
        will not work in some conditions, like subquery pushdown.

        A parallel method is get_extra_descriptor_filter() which is used in
        instance.fieldname related object fetching.
        Nr4)r*�where_class�alias�
related_aliasr4r4r5�get_extra_restriction�sz#ForeignObject.get_extra_restrictionc	Cs,|jjj}|jj}t|||j|dd|d�gS)z.Get path from this field to the related model.FT��	from_opts�to_optsr��
join_field�m2m�direct�filtered_relation)rIr:r0rr��r*r!rlrr4r4r5r��s
�zForeignObject.get_path_infoc	C�4|jj}|jjj}t|||jf|j|jd|d�gS�z6Get path from the related model to this field's model.Fr�r:r0rIrr�r�r"r4r4r5�get_reverse_path_info��
�z#ForeignObject.get_reverse_path_info)�maxsizecCs8t�|�}|d|�t�d�}dd�|D�}|�|�S)NrcSsg|]	}|j�di��qS)�
class_lookups)�__dict__�get)r7�parentr4r4r5r;�sz-ForeignObject.get_lookups.<locals>.<listcomp>)�inspect�getmror�r��merge_dicts)r��basesr)r4r4r5�get_lookups�s

zForeignObject.get_lookupscs2t�j||fd|i|��t||j|�|��dS)Nr�)rMr��setattrrc�forward_related_accessor_class)r*r�rcr�rCrUr4r5r��sz!ForeignObject.contribute_to_classcCsX|j��s&|jjjs(t|jj|��|�|��|jj	r*|jj
�|jj	�dSdSdSdSr<)rIrfrKr0rnr2�concrete_modelry�related_accessor_classr��related_fkey_lookupsrh�r*r�r�r4r4r5r��s�z)ForeignObject.contribute_to_related_class)NNNNFTr�r<),r�r�r�r�r{r�r�r�r�rr5rr3r&r�r�rNr�r�r�r�rr�r�rr�rr
�staticmethodrrrrr�rr�r&�classmethod�	functools�	lru_cacher1r�r�r�r4r4rUr5r��sV�C#








r�csDeZdZdZeZdZdZdZdZ	e
ZdZde
d�iZe
d�Z			d9�fdd	�	Z�fd
d�Zdd
�Zdd�Z�fdd�Zdd�Zedd��Zd:dd�Z�fdd�Z�fdd�Zdd�Zdd�Z�fd d!�Zd"d#�Zd;d$d%�Zd&d'�Z �fd(d)�Z!dd*��fd+d,�
Z"d-d.�Z#d/d0�Z$d1d2�Z%d3d4�Z&�fd5d6�Z'd:�fd7d8�	Z(�Z)S)<�
ForeignKeyz�
    Provide a many-to-one relation by adding a column to the local model
    to hold the remote value.

    By default ForeignKey will target the pk of the remote model but this
    behavior can be changed by using the ``to_field`` argument.
    FT�invalidz;%(model)s instance with %(field)s %(value)r does not exist.z.Foreign Key (type determined by related field)Nc	

s�z|jjWntyt|t�sJd|jj|tf��Ynw|p*|jjo*|jjj	}t
|�s3td��|j||||||||d�|	d<|	�
dd�t�j||ftg|gd�|	��||_dS)Nzg%s(%r) is invalid. First parameter to ForeignKey must be either a model, a model name, or the string %rzon_delete must be callable.r�r8�db_indexT)r�r�)r0rq�AttributeErrorr.r/rVr�r-r�rcr��	TypeErrorr��
setdefaultrMr��
db_constraint)
r*r�r�r]rgr�r�r�rBrCrUr4r5r�sB����
����
zForeignKey.__init__cr�rL)rMrN�_check_on_delete�
_check_uniquerTrUr4r5rNBr�zForeignKey.checkcCsXt|jdd�}|tkr|jstjdd|dd�gS|tkr*|��s*tjdd|dd�gSgS)	Nr�z7Field specifies on_delete=SET_NULL, but cannot be null.zBSet null=True argument on the field, or change the on_delete rule.zfields.E320rXz@Field specifies on_delete=SET_DEFAULT, but has no default value.z2Set a default value, or change the on_delete rule.zfields.E321)r�rIr�nullrrar�has_default)r*r�r4r4r5rCIs$����	zForeignKey._check_on_deletecKs|jr
tjdd|dd�gSgS)NzQSetting unique=True on a ForeignKey has the same effect as using a OneToOneField.zDForeignKey(unique=True) is usually better served by a OneToOneField.zfields.W342rX)r�r�WarningrTr4r4r5rD`s����zForeignKey._check_uniquecs�t���\}}}}|d=|d=|jr|d=nd|d<|jdur$|j|d<t|jjdd�}|jjrC|r=|jrC|jj|jj	krC|jj|d<||||fS)	Nr�r�r>FTrBr0r�)
rMr�r>rBr�rIr:r�r�rc)r*rcr�r�rC�to_metarUr4r5r�js"

��zForeignKey.deconstructcC�|j�|�Sr<)r��	to_python�r*�valuer4r4r5rJ|rzForeignKey.to_pythoncCs
|jdS)Nr)r�rJr4r4r5r�s
zForeignKey.target_fieldc	Cr#r$r%r"r4r4r5r&�r'z ForeignKey.get_reverse_path_infocs�|jjrdSt��||�|durdStj|jj|d�}|jjj�|�j	di|jj
|i��}|�|���}|�
�sOtj|jdd|jjjj||jj
|d�d��dS)N)rr=)r:r�rvrL)�code�paramsr4)rIr�rM�validater
�db_for_readr:�
_base_manager�using�filterr��complex_filterr��existsr�ValidationError�error_messagesr0r�)r*rL�model_instancerR�qsrUr4r5rO�s&
����zForeignKey.validatecs^t���}|D]%\}}|r,|j|jjjjkr,t�d|jjj|j	|j	|jjjjjjf��q|S)Nz>'%s.%s' refers to field '%s' which is not local to model '%s'.)
rMr�r:rIr0r4rr�rrrc)r*r�r�r�rUr4r5r��s
����	z!ForeignKey.resolve_related_fieldscCs
d|jS)Nz%s_idr�rJr4r4r5�get_attname��
zForeignKey.get_attnamecCs|��}|jp|}||fSr<)rZ�	db_columnrr4r4r5r�s
zForeignKey.get_attname_columncs*t���}t||jj�rt||jj�S|S)z6Return the to_field if the default value is an object.)rM�get_defaultr.rIr:r�r�r�)r*�
field_defaultrUr4r5r]�s
zForeignKey.get_defaultcCs4|dus|dkr|jjr|jjrdS|jj||d�S)N��r	)r��empty_strings_allowed�features�!interprets_empty_strings_as_nulls�get_db_prep_save)r*rLr	r4r4r5rd�s��zForeignKey.get_db_prep_savecCs|j�|||�Sr<)r��get_db_prep_value)r*rLr	�preparedr4r4r5re�szForeignKey.get_db_prep_valuecCrIr<)r��get_prep_valuerKr4r4r5rg�rzForeignKey.get_prep_valuecs0t��||�|jjdur|jjj|j_dSdSr<)rMr�rIr�r0r�rcr7rUr4r5r��s�z&ForeignKey.contribute_to_related_class�rRcs^t|jjt�rtd|j|jjf��t�jditj	|jjj
�|�|jjd�|�d|j
i���S)NzYCannot create form field for %r yet, because its related model %r has not been loaded yet)�
form_class�querysetr��blankr4)r.rIr:r/r�rcrMr�r�ModelChoiceField�_default_managerrRr�rk)r*rRrCrUr4r5r��s�
��
�zForeignKey.formfieldcC�gSr<r4r�r4r4r5�db_check��zForeignKey.db_checkcCs|jj|d�S)Nr`)r��rel_db_typer�r4r4r5r��r	zForeignKey.db_typecCs|�|�|�|�d�S�N)�typerN)r�ror�r4r4r5�
db_parameters��zForeignKey.db_parameterscCs|s	t|t�r	dS|Sr<)r.r/)r*rL�
expressionr	r4r4r5�convert_empty_strings�sz ForeignKey.convert_empty_stringscs$t��|�}|jjr||jg7}|Sr<)rM�get_db_convertersrbrcrw)r*r	�
convertersrUr4r5rx�szForeignKey.get_db_converterscsF|dur|j}t|t�r|j}||urtd��t|t�st��||�S)NzCannot resolve output_field.)r�r.r<r�rM�get_col)r*r�output_fieldrUr4r5rz�s

�zForeignKey.get_col)NNNFNTr<r�)*r�r�r�r�r�descriptor_classr{r�r�r�r(r�rare�default_error_messages�descriptionr�rNrCrDr�rJr�r�r&rOr�rZrr]rdrergr�r�ror�rtrwrxrzr�r4r4rUr5r<sP��(




r<csneZdZdZdZdZdZdZeZ	e
ZeZ
ed�Zd�fdd�	Z�fdd	�Z�fd
d�Zdd
�Zdd�Z�ZS)�
OneToOneFielda
    A OneToOneField is essentially the same as a ForeignKey, with the exception
    that it always carries a "unique" constraint with it and the reverse
    relation always returns the object pointed to (since there will only ever
    be one), rather than returning a list.
    FTzOne-to-one relationshipNcs&d|d<t�j||fd|i|��dS)NTr�r�)rMr�)r*r�r�r�rCrUr4r5r�szOneToOneField.__init__cs,t���\}}}}d|vr|d=||||fS)Nr�)rMr�r�rUr4r5r�szOneToOneField.deconstructcs|jjrdSt�jdi|��SrL)rIr�rMr�rTrUr4r5r�!szOneToOneField.formfieldcCsLt||jj�rt||j|�dSt||j|�|dur$t||j|�dSdSr<)r.rIr:r2rcr��r*r�datar4r4r5�save_form_data&s�zOneToOneField.save_form_datacKrnr<r4rTr4r4r5rD0szOneToOneField._check_uniquer<)r�r�r�r�r{r�r�r�rr5rr3r)r�rer~r�r�r�r�rDr�r4r4rUr5rs
rc	Csddlm}dd�}t||jj�}d|jj|jf}t||||�t	|�d}|jj
}||kr7d|}d|}td	d
|�|j�||jj
|jj||ftd�||d�td
�||d�|jjjd��}t||jfd	|d|j||j|d||j|jjtd�||j|d||j|jjtd�i�S)Nr)rDcSs|jjp|jj|j_dSr<)r0�managed)r:r��throughr4r4r5�set_managed8sz;create_many_to_many_intermediary_model.<locals>.set_managed�%s_%srzto_%szfrom_%s�Metar4z%(from)s-%(to)s relationship)�fromr�z%(from)s-%(to)s relationships)�db_table�auto_createdr1�
db_tablespacer�r��verbose_name_pluralrr�z%s+)r]r�rBr�)�	django.dbrDr6rIr:r0rbrcrFrrqrs�_get_m2m_db_tabler1r�rer�Modelr�r<rBr)	rv�klassrDr��to_modelrcr��from_�metar4r4r5�&create_many_to_many_intermediary_model5sL
�
���r�cseZdZdZdZdZdZdZeZ	e
d�Z				d3�fdd�	Z�fdd	�Z
d
d�Zdd
�Zd4dd�Zdd�Z�fdd�Zd5dd�Zd4dd�Zd4dd�Zdd�Zdd�Zdd�Z�fd d!�Zd"d#�Zd$d%�Zd&d'�Zd(d)�Zdd*��fd+d,�
Zd-d.�Zd/d0�Z d1d2�Z!�Z"S)6�ManyToManyFieldaK
    Provide a many-to-many relation by using an intermediary model that
    holds two ForeignKey fields pointed at the two sides of the relation.

    Unless a ``through`` model was provided, ManyToManyField will use the
    create_many_to_many_intermediary_model factory to automatically generate
    the intermediary model.
    TFzMany-to-many relationshipNcs�z|jWntyt|t�sJd|jj|tf��Ynw|dur'|tk}|dur3|	dus3Jd��|j|||||||||d�	|d<d|v|_t	�j
di|��|	|_|
|_dS)Nzl%s(%r) is invalid. First parameter to ManyToManyField must be either a model, a model name, or the string %rz;Cannot specify a db_table if an intermediary model is used.)r]rgr��symmetricalr��through_fieldsrBr8rEr4)
r0r?r.r/rVr�r-r��has_null_argrMr�r�rs)r*r�r]rgr�r�r�r�rBr�rsrCrUr4r5r�xs:
���
�
�


zManyToManyField.__init__csVgt�jdi|���|jdi|���|jdi|���|jdi|���|jdi|���SrL)rMrNrD�_check_relationship_model�_check_ignored_options�_check_table_uniquenessrTrUr4r5rN�s�����zManyToManyField.checkcKs|jrtjd|dd�gSgS)Nz"ManyToManyFields cannot be unique.zfields.E330rk)r�rrarTr4r4r5rD�s��zManyToManyField._check_uniquecKsrg}|jr|�tjd|dd��|jr|�tjd|dd��|jjr7|jjr7|jjjj	s7|�tjd|dd��|S)Nz&null has no effect on ManyToManyField.zfields.W340rkz,ManyToManyField does not support validators.zfields.W341zGlimit_choices_to has no effect on ManyToManyField with a through model.zfields.W343)
r�rhrrG�_validatorsrIr�r�r0r�)r*rC�warningsr4r4r5r��s8����
���	z&ManyToManyField._check_ignored_optionscs�t|jjd�rd|jjjj|jjjf}n|jj}g}|jj|jjjdd�vr5|�	t
jd||dd��nňdus=Jd��t�|jj
���jj}t�t�rP�}n�jj}|jjjj}��k}|r�t�fd	d
�|jjjjD��}	|	dkr�|jjs�|�	t
jd||fd
|jjdd��npt�fdd
�|jjjjD��}
t�fdd
�|jjjjD��}|
dkr�|jjs�|�	t
jd||fdt|f|dd��|dkr�|jjs�|�	t
jd||fdt|f|dd��|
dks�|dkr�|�	t
jd|||f|jjdd��|jjdu�r�t|jj�dk�r|jjd�r|jjd�s(|�	t
jd|d|dd��|S�du�s1Jd���|jj|jj
}}
}|jjdd�\}}||f||ffD]�\}}g}|
jjD]}t|d��rqt|jdd�|k�rq|�	|j��qY|�r�d |jjd!�|�f}nd}z|
j�|�}Wntj�y�|�	t
jd"||f||d#d��Y�qOwt|d��r�t|jdd�|k�s�|�	t
jd$|
jj||jjf||d%d���qO|S)&Nr0r,T��include_auto_createdzYField specifies a many-to-many relation through model '%s', which has not been installed.zfields.E331rkzvManyToManyField with intermediate tables cannot be checked if you don't pass the model where the field is attached to.c3�"�|]}�t|jdd�kVqdS�r:N�r�rI�r7rv��
from_modelr4r5r>��
��
�z<ManyToManyField._check_relationship_model.<locals>.<genexpr>�z�The model is used as an intermediate model by '%s', but it has more than two foreign keys to '%s', which is ambiguous. You must specify which two foreign keys Django should use via the through_fields keyword argument.zGUse through_fields to specify which two foreign keys Django should use.zfields.E333rXc3r�r�r�r�r�r4r5r>
r�c3r�r�r�r�)r�r4r5r>r�rz�The model is used as an intermediate model by '%s', but it has more than one foreign key from '%s', which is ambiguous. You must specify which foreign key Django should use via the through_fields keyword argument.zXIf you want to create a recursive relationship, use ManyToManyField("%s", through="%s").zfields.E334z�The model is used as an intermediate model by '%s', but it has more than one foreign key to '%s', which is ambiguous. You must specify which foreign key Django should use via the through_fields keyword argument.zfields.E335rzgThe model is used as an intermediate model by '%s', but it does not have a foreign key to '%s' or '%s'.zfields.E336z�Field specifies 'through_fields' but does not provide the names of the two link fields that should be used for the relation through model '%s'.zMMake sure you specify 'through_fields' as through_fields=('field1', 'field2')zfields.E337rIr:z;Did you mean one of the following foreign keys to '%s': %s?r�z.The intermediary model '%s' has no field '%s'.zfields.E338z%'%s.%s' is not a foreign key to '%s'.zfields.E339)r�rIr�r0r1r�rlrrmrhrrar6r:rbr.r/�sumrzr�r-r�r�rcr�r�rr�)r*r�rC�qualified_model_namerj�from_model_name�
to_model_name�relationship_model_name�self_referential�	seen_self�	seen_from�seen_torr��target�source_field_name�target_field_namer�rK�possible_field_namesr�rYrvr4)r�r�r5r��s4����

�

�����
�
���������������
�
����B��� ����
������z)ManyToManyField._check_relationship_modelcs�t�jjt�s
�jjjjsgS�fdd��jjjdd�D�}��	�}|�
|�}|rq|jj�jjjjkrq|jjrJdd�}|jjj}d|j
||�f}n|jj
}tjr\tjd}}	d	|}
ntjd
}}	d}
|d||f�|
|	d�gSgS)
Ncs*i|]}|�jjkr|jjr|jj|�qSr4)rIr�r0r�r�)r7r:rJr4r5r��s
�z;ManyToManyField._check_table_uniqueness.<locals>.<dictcomp>Tr�cSs,|jjjjD]
}|jj|ur|jSqdSr<)r0r�r{rIr�rc)r:rvr4r4r5�_get_field_name�s

��z@ManyToManyField._check_table_uniqueness.<locals>._get_field_namer,zfields.W344zvYou have configured settings.DATABASE_ROUTERS. Verify that the table of %r is correctly routed to a separate database.zfields.E340zHThe field's intermediary table '%s' clashes with the table name of '%s'.)rZrYr[)r.rIr�r/r0r�rlrrm�m2m_db_tabler+r4r�rrr�DATABASE_ROUTERSrrGra)r*rC�registered_tablesr�r:r�rl�clashing_obj�error_class�error_id�
error_hintr4rJr5r��s>
�

�����	z'ManyToManyField._check_table_uniquenesscst���\}}}}|jdur|j|d<|jjdur|jj|d<t|jjt�r-|jj|d<n|jjjj	|d<t
|jdd�durZt|jjt�rL|jj|d<n|jjjjsZ|jjjj	|d<|j
}|dur�t|dd�rz|dj|krztd|dj|f��t|d|�|d<||||fS)Nr�TrBr�r�r�ztCannot deconstruct a ManyToManyField pointing to a model that is swapped in place of more than one model (%s and %s))rMr�r�rIrBr.r:r/r0rrr�r�r�r�r�r�r�r)r*rcr�r�rCr�rUr4r5r��s6

���zManyToManyField.deconstructcCs�|jj}|j�|���}|j�|���}|r |��}|�|�}n	|��}|�|�}|dj}|dj	}	||	ur:g}
nt
|j|	j�rH|�|	j�}
n|	�
|j�}
g|�|
�|�S)z1Called by both direct and indirect m2m traversal.r�r)rIr�r0r��m2m_field_name�m2m_reverse_field_namer&r�rr�
issubclassr:�get_path_to_parent�get_path_from_parent)r*r r!�	int_model�
linkfield1�
linkfield2�
join1infos�
join2infos�join1_final�
join2_initial�intermediate_infosr4r4r5�_get_path_info�s 


zManyToManyField._get_path_infocC�|jd|d�S)NT�r r!�r��r*r!r4r4r5r��r	zManyToManyField.get_path_infocCr�)NFr�r�r�r4r4r5r&r	z%ManyToManyField.get_reverse_path_infocCsL|jjdur|jjjjS|jr|jSdt�|j�|jf}t�|tj	�
��S)zg
        Function that can be curried to provide the m2m table name for this
        relation.
        Nr�)rIr�r0r�r�strip_quotesrc�
truncate_namer	�ops�max_name_length)r*rl�m2m_table_namer4r4r5r�sz!ManyToManyField._get_m2m_db_tablecCs�d|}t||�rt||�S|jjdur|jjd}nd}|jjjjD]%}|jrH|jj|j	krH|dus8||j
krHt||t||��t||�Sq#dS)zz
        Function that can be curried to provide the source accessor or DB
        column name for the m2m table.
        z
_m2m_%s_cacheNr)r�r�rIr�r�r0rz�is_relationr:rKrcr2)r*r��attr�
cache_attr�link_field_namer�r4r4r5�
_get_m2m_attrs

��zManyToManyField._get_m2m_attrcCs�d|}t||�rt||�Sd}|jjdur|jjd}nd}|jjjjD]:}|jr_|jj|jkr_|durK|j	|jkrK|rHt
||t||��nd}q%|dusT||jkr_t
||t||��nq%t||�S)z{
        Function that can be curried to provide the related accessor or DB
        column name for the m2m table.
        z_m2m_reverse_%s_cacheFNrT)r�r�rIr�r�r0rzr�r:rKr2rc)r*r�r�r��foundr�r�r4r4r5�_get_m2m_reverse_attr"s&

�
z%ManyToManyField._get_m2m_reverse_attrcs�|jjr|jjtks|jj|jjkrd||j_n|j��r,d|jj|j	�
�|f|j_t�j||fi|��|jj
sY|jjrNdd�}t|||jj|d�n|jjsYt||�|j_t||jt|jdd��t|j|j�|_dS)Nz%s_rel_+z_%s_%s_%s_+cSs||j_dSr<)rIr�)rer:rvr4r4r5�resolve_through_model_rzBManyToManyField.contribute_to_class.<locals>.resolve_through_modelruF��reverse)rIr�r:r-r0rbr]rfr1r�r�rMr�r�r�rFrnr�r2rcrrr�r�)r*r�rcrCr�rUr4r5r�@s&

�z#ManyToManyField.contribute_to_classcs�|j��s|jjjst||��t|jdd��t|j	|d�|_
t|j|d�|_t|j	|d�|_
t|j|d�|_t|j	|d���fdd�|_t|j|d���fdd�|_dS)	NTr�rrcrIc���jSr<�r�r4)�get_m2m_relr4r5�<lambda>y�z=ManyToManyField.contribute_to_related_class.<locals>.<lambda>cr�r<r�r4)�get_m2m_reverse_relr4r5r�{r�)rIrfrKr0rnr2ryrrr��m2m_column_namer��m2m_reverse_namer�r��m2m_target_field_name�m2m_reverse_target_field_namer7r4)r�r�r5r�ksz+ManyToManyField.contribute_to_related_classcCr�r<r4rJr4r4r5r�}rpz'ManyToManyField.set_attributes_from_relcCs"|jdurgStt||j����Sr<)r��listr�r��allr�r4r4r5�value_from_object�s"z!ManyToManyField.value_from_objectcCst||j��|�dSr<)r�r��setr�r4r4r5r��ruzManyToManyField.save_form_datarhcsdtj|jjj�|�d�|�}|�d�dur)|d}t|�r |�}dd�|D�|d<t�j	di|��S)N)rirj�initialcSsg|]}|j�qSr4)r�)r7�ir4r4r5r;�r�z-ManyToManyField.formfield.<locals>.<listcomp>r4)
r�ModelMultipleChoiceFieldrIr:rmrRr+r�rMr�)r*rRrCr�r�rUr4r5r��s��zManyToManyField.formfieldcCr�r<r4r�r4r4r5ro�rpzManyToManyField.db_checkcCr�r<r4r�r4r4r5r��r�zManyToManyField.db_typecCs
ddd�Srrr4r�r4r4r5rt�r[zManyToManyField.db_parameters)	NNNNNNTNTr<)FN)#r�r�r�r�r{r�r�r�r'r�rer~r�rNrDr�r�r�r�r�r�r&r�r�r�r�r�r�r�r�r�ror�rtr�r4r4rUr5r�dsF
�&	
!B+
$


+r�)Er:r-r�djangor�django.appsr�django.confrr�django.corerrr�r	r
�django.db.backendsr�django.db.modelsr�django.db.models.constantsr
�django.db.models.deletionrrr�django.db.models.query_utilsr�django.db.models.utilsr�django.utils.functionalr�django.utils.translationrrer_r�mixinsr�related_descriptorsrrrrrr�related_lookupsrr r!r"r#r$r%�reverse_relatedr&r'r(r)r-r6rFrGr��register_lookupr<rr�r�r4r4r4r5�<module>sV $k
@





2/