a
    ŠxdK  ã                   @   sŠ   d dl Z d dlmZ d dlZd dlmZmZmZ d dl	m
Z
 d dlmZ edejd ƒZedƒZd	d
„ ZG dd„ dƒZG dd„ deƒZdS )é    N)Ú
namedtuple)ÚBaseDatabaseIntrospectionÚ	FieldInfoÚ	TableInfo)ÚIndex)Ú_lazy_re_compiler   )ÚpkÚhas_json_constraintz&^\s*(?:var)?char\s*\(\s*(\d+)\s*\)\s*$c                 C   s   t  | ¡}|rt|d ƒS dS )z8 Extract the size number from a "varchar(11)" type name é   N)Úfield_size_reÚsearchÚint)ÚnameÚm© r   ú`/var/www/html/Ranjet/env/lib/python3.9/site-packages/django/db/backends/sqlite3/introspection.pyÚget_field_size   s    
r   c                   @   s@   e Zd Zdddddddddddd	d
dddddddœZdd„ ZdS )ÚFlexibleFieldLookupDictZBooleanFieldÚSmallIntegerFieldZPositiveSmallIntegerFieldÚIntegerFieldÚBigIntegerFieldZPositiveIntegerFieldZPositiveBigIntegerFieldZDecimalFieldZ
FloatFieldZ	TextFieldZ	CharFieldZBinaryFieldZ	DateFieldZDateTimeFieldZ	TimeField)ÚboolÚbooleanZsmallintzsmallint unsignedZsmallintegerr   ÚintegerZbigintzinteger unsignedzbigint unsignedÚdecimalÚrealÚtextÚcharZvarcharZblobÚdateÚdatetimeÚtimec                 C   s"   |  ¡  dd¡d  ¡ }| j| S )Nú(r
   r   )ÚlowerÚsplitÚstripÚbase_data_types_reverse)ÚselfÚkeyr   r   r   Ú__getitem__4   s    z#FlexibleFieldLookupDict.__getitem__N)Ú__name__Ú
__module__Ú__qualname__r%   r(   r   r   r   r   r      s*   ír   c                       st   e Zd Zeƒ Z‡ fdd„Zdd„ Zdd„ Zddd	„Zd
d„ Z	dd„ Z
dd„ Zdd„ Zdd„ Zdd„ Zdd„ Z‡  ZS )ÚDatabaseIntrospectionc                    s.   t ƒ  ||¡}|jr |dv r dS |jr*dS |S )N>   r   r   r   Z	AutoFieldZ	JSONField)ÚsuperÚget_field_typer   r	   )r&   Ú	data_typeÚdescriptionZ
field_type©Ú	__class__r   r   r.   <   s    z$DatabaseIntrospection.get_field_typec                 C   s   |  d¡ dd„ | ¡ D ƒS )z>Return a list of table and view names in the current database.z–
            SELECT name, type FROM sqlite_master
            WHERE type in ('table', 'view') AND NOT name='sqlite_sequence'
            ORDER BY namec                 S   s"   g | ]}t |d  |d d  ƒ‘qS )r   r
   )r   )Ú.0Úrowr   r   r   Ú
<listcomp>N   ó    z8DatabaseIntrospection.get_table_list.<locals>.<listcomp>)ÚexecuteÚfetchall)r&   Úcursorr   r   r   Úget_table_listF   s    
z$DatabaseIntrospection.get_table_listc                    s~   |  d| jj |¡ ¡ | ¡ }tƒ ‰ | jjjrl|D ]6}|d }d| }|  d||g¡ ¡ }|r4ˆ  	|¡ q4‡ fdd„|D ƒS )zi
        Return a description of the table with the DB-API cursor.description
        interface.
        zPRAGMA table_info(%s)r
   z%%json_valid("%s")%%zæ
                    SELECT sql
                    FROM sqlite_master
                    WHERE
                        type = 'table' AND
                        name = %s AND
                        sql LIKE %s
                c                    s@   g | ]8\}}}}}}t ||d t|ƒd d | ||dk|ˆ v ƒ
‘qS )Nr
   )r   r   )r3   Zcidr   r/   ZnotnullÚdefaultr   ©Zjson_columnsr   r   r5   f   s
   üþz?DatabaseIntrospection.get_table_description.<locals>.<listcomp>)
r7   Ú
connectionÚopsÚ
quote_namer8   ÚsetÚfeaturesZcan_introspect_json_fieldÚfetchoneÚadd)r&   r9   Ú
table_nameZ
table_infoÚlineÚcolumnZjson_constraint_sqlr	   r   r<   r   Úget_table_descriptionP   s    
ù
ûz+DatabaseIntrospection.get_table_descriptionr   c                 C   s   |   ||¡}||dœgS )N)ÚtablerF   )Úget_primary_key_column)r&   r9   rD   Ztable_fieldsZpk_colr   r   r   Úget_sequencesn   s    z#DatabaseIntrospection.get_sequencesc                 C   s~  i }|  d|g¡ | ¡ \}}|dkr*|S || d¡d | d¡… }| d¡D ]&}| ¡ }| d¡rjqPt d|tj	¡}|s€qPd	d
„ | 
¡ D ƒ\}	}
| d¡rÀt d|tj	¡}|d  d¡}n| ¡ d  d¡}|  d|	g¡ | ¡ d }|d  ¡ }| d¡| d¡ }}||d |… }| d¡D ]N}| ¡ }| d¡rDq(| dd¡d  d¡}||
kr(||	f||<  qPq(qP|S )z—
        Return a dictionary of {field_name: (field_name_other_table, other_table)}
        representing all relationships to the given table.
        úUSELECT sql, type FROM sqlite_master WHERE tbl_name = %s AND type IN ('table', 'view')Úviewr!   r
   ú)ú,ÚUNIQUEz$references (\S*) ?\(["|]?(.*)["|]?\)c                 S   s   g | ]}|  d ¡‘qS )ú"©r$   ©r3   Úsr   r   r   r5   ‘   r6   z7DatabaseIntrospection.get_relations.<locals>.<listcomp>zFOREIGN KEYzFOREIGN KEY\s*\(([^\)]*)\).*rP   r   z1SELECT sql FROM sqlite_master WHERE tbl_name = %sú )r7   rB   ÚindexÚrindexr#   r$   Ú
startswithÚrer   ÚIÚgroupsÚmatchr8   )r&   r9   rD   Z	relationsÚ
create_sqlÚ
table_typeÚresultsÚ
field_descr   rH   rF   Ú
field_nameÚresultZother_table_resultsÚliÚriZ
other_descZ
other_namer   r   r   Úget_relationsr   sF    ý



z#DatabaseIntrospection.get_relationsc                 C   s¢   g }|  d|dg¡ | ¡ d  ¡ }|| d¡d | d¡… }t| d¡ƒD ]N\}}| ¡ }| d¡rjqNt 	d	|tj
¡}|s€qN| td
d„ | ¡ D ƒƒ¡ qN|S )z‹
        Return a list of (column_name, referenced_table_name, referenced_column_name)
        for all key columns in given table.
        z?SELECT sql FROM sqlite_master WHERE tbl_name = %s AND type = %srH   r   r!   r
   rM   rN   rO   z("(.*)".*references (.*) \(["|](.*)["|]\)c                 s   s   | ]}|  d ¡V  qdS )rP   NrQ   rR   r   r   r   Ú	<genexpr>Å   r6   z8DatabaseIntrospection.get_key_columns.<locals>.<genexpr>)r7   rB   r$   rU   rV   Ú	enumerater#   rW   rX   r   rY   ÚappendÚtuplerZ   )r&   r9   rD   Zkey_columnsr^   Zfield_indexr_   r   r   r   r   Úget_key_columns¬   s    
z%DatabaseIntrospection.get_key_columnsc           	      C   s¢   |  d|g¡ | ¡ }|du r*td| ƒ‚|\}}|dkr>dS || d¡d | d¡… }| d¡D ]8}| ¡ }t d	|¡}|rd|d r|d n|d
   S qddS )z>Return the column name of the primary key for the given table.rK   NzTable %s does not existrL   r!   r
   rM   rN   z1(?:(?:["`\[])(.*)(?:["`\]])|(\w+)).*PRIMARY KEY.*é   )	r7   rB   Ú
ValueErrorrU   rV   r#   r$   rX   r[   )	r&   r9   rD   r4   r\   r]   Z
fields_sqlr_   r   r   r   r   rI   É   s"    ýz,DatabaseIntrospection.get_primary_key_columnc           
      C   sd   i }|  d| jj |¡ ¡ | ¡ D ]:}|d d… \}}}}}	|gdd||	fdddœ|d| < q$|S )NzPRAGMA foreign_key_list(%s)é   F©ÚcolumnsÚprimary_keyÚuniqueÚforeign_keyÚcheckrU   zfk_%d)r7   r=   r>   r?   r8   )
r&   r9   rD   Úconstraintsr4   Zid_Ú_rH   Úfrom_Útor   r   r   Ú_get_foreign_key_constraintsà   s    úz2DatabaseIntrospection._get_foreign_key_constraintsc                 C   sÆ  d }d }d }d }d}g }d}	g }
d}|D ]V}|  tjjd¡rH|d7 }nF|  tjjd¡rp|d8 }|dk rŽ q‚n|dkrŽ|  tjjd¡rŽ q‚|d u r¬|  tjjd¡}|r¬q(|r~|d u rø|jtjjtjjfv rØ|j}n |jtjjj	j
krø|jdd… }|  tjjd	¡rd
}|}nh|râ||kr.|r(d}q(|jtjjtjjfv rT| |j¡ n(|jtjjj	j
krâ| |jdd… ¡ nd|d u rÊ|jtjjtjjfv r¨|j}n"|jtjjj	j
krÊ|jdd… }|  tjjd	¡râ|g}|  tjjd¡rþd
}	|}q(|	r(||kr|
r(d}	q(|jtjjtjjfv rH|j|v r€|
 |j¡ q(|jtjjj	j
kr(|jdd… |v r(|
 |jdd… ¡ q(|ršd
|dd dddœnd }|
r¶d
|
ddd ddœnd }||||fS )NFr   r!   r
   rM   rN   Z
CONSTRAINTéÿÿÿÿrO   TZCHECK)rp   rn   ro   rq   rr   rU   )rr   rn   ro   rp   rq   rU   )r[   ÚsqlparseÚtokensÚPunctuationÚKeywordÚttypeÚNameÚvalueÚLiteralÚStringZSymbolrg   )r&   rz   rn   ÚtokenZis_constraint_definitionr`   Úconstraint_namerp   Zunique_columnsrr   Zcheck_columnsZbraces_deepZunique_braces_deepZcheck_braces_deepZunique_constraintZcheck_constraintr   r   r   Ú&_parse_column_or_constraint_definitionð   s¨    




ùúùùúùz<DatabaseIntrospection._parse_column_or_constraint_definitionc                 C   s¾   t  |¡d }i }d}dd„ | ¡ D ƒ}|D ]}| t jjd¡r, qFq,|  ||¡\}}	}
}|	r€|rl|	||< n|d7 }|	|d| < |
r¦|r’|
||< n|d7 }|
|d| < | t jjd¡rFqºqF|S )Nr   c                 s   s   | ]}|j s|V  qd S ©N)Zis_whitespace)r3   r‚   r   r   r   re   P  r6   zADatabaseIntrospection._parse_table_constraints.<locals>.<genexpr>r!   r
   z__unnamed_constraint_%s__rM   )ry   ÚparseÚflattenr[   rz   r{   r„   )r&   Úsqlrn   Z	statementrs   Zunnamed_constrains_indexrz   r‚   rƒ   rp   rr   Z	end_tokenr   r   r   Ú_parse_table_constraintsJ  s*    

z.DatabaseIntrospection._parse_table_constraintsc              	   C   sÌ  i }z&|  d| jj |¡f ¡ ¡ d }W n ty<   Y n*0 dd„ |  ||¡D ƒ}| |  ||¡¡ |  d| jj |¡ ¡ | 	¡ D ]}|dd… \}}}	|  d| jj |¡ ¡ | ¡ pÀd	\}
|
sÊq†|  d
| jj |¡ ¡ | 	¡ D ]@\}}}||vrg dt
|	ƒddddœ||< || d  |¡ qê|| d r†|| d s†tj|| d< |
 d¡d  d¡d  d¡}dd„ |D ƒ}||| d< q†|  ||¡}|r¶|gddddddœ|d< | |  ||¡¡ |S )zu
        Retrieve any constraints or keys (unique, pk, fk, check, index) across
        one or more columns.
        z<SELECT sql FROM sqlite_master WHERE type='table' and name=%sr   c                 S   s   h | ]
}|j ’qS r   )r   ©r3   Úinfor   r   r   Ú	<setcomp>y  r6   z8DatabaseIntrospection.get_constraints.<locals>.<setcomp>zPRAGMA index_list(%s)Né   z<SELECT sql FROM sqlite_master WHERE type='index' AND name=%sr…   zPRAGMA index_info(%s)FTrm   rn   rU   rp   Útyper!   rx   rM   rN   c                 S   s   g | ]}|  d ¡rd nd‘qS )ZDESCÚASC)ÚendswithrŠ   r   r   r   r5   £  r6   z9DatabaseIntrospection.get_constraints.<locals>.<listcomp>ÚordersZ__primary__)r7   r=   r>   r?   rB   Ú	TypeErrorrG   Úupdater‰   r8   r   rg   r   Úsuffixr#   rI   rw   )r&   r9   rD   rs   Ztable_schemarn   r4   ÚnumberrU   rp   rˆ   Z
index_rankZcolumn_rankrF   Z
order_infor‘   Z	pk_columnr   r   r   Úget_constraintsh  sf    ÿÿüÿÿ
ú
ú
z%DatabaseIntrospection.get_constraints)r   )r)   r*   r+   r   Zdata_types_reverser.   r:   rG   rJ   rd   ri   rI   rw   r„   r‰   r–   Ú__classcell__r   r   r1   r   r,   9   s   


:Zr,   )rX   Úcollectionsr   ry   Z%django.db.backends.base.introspectionr   r   ZBaseFieldInfor   Zdjango.db.modelsr   Zdjango.utils.regex_helperr   Ú_fieldsr   r   r   r,   r   r   r   r   Ú<module>   s   	