3
gX                 @   s  d Z ddlZddlZddlZddl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 ddlmZ dd	lmZmZ dd
lmZ dd Zed'd(g yddlZW n. ek
r Z ze
de W Y ddZ[X nX 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$ ddl%m&Z& ddl'm(Z(m)Z) ddl*m+Z+ edd Z,G dd dZ-G dd  d eZ.G d!d" d"Z/G d#d$ d$Z0G d%d& d&Z1dS ))ze
Oracle database backend for Django.

Requires cx_Oracle: https://oracle.github.io/python-cx_Oracle/
    N)contextmanager)settings)ImproperlyConfigured)IntegrityError)BaseDatabaseWrapper)async_unsafe)force_bytes	force_str)cached_propertyc             C   s   t j j jdrxydd l}W n. tk
rL } ztd| W Y d d }~X nX |jd}x*| D ]\}}|j|| q^W nt	j
j|  d S )NZCYGWINr   z_Error loading ctypes: %s; the Oracle backend requires ctypes to operate correctly under Cygwin.kernel32)platformsystemupper
startswithctypesImportErrorr   CDLLZSetEnvironmentVariableAosenvironupdate)r   r   er   namevalue r   \/var/www/tester-filtro-web/env/lib/python3.6/site-packages/django/db/backends/oracle/base.py_setup_environment   s    
r   NLS_LANG	.AL32UTF8ORA_NCHAR_LITERAL_REPLACETRUEz"Error loading cx_Oracle module: %s   )DatabaseClient)DatabaseCreation)DatabaseFeatures)DatabaseIntrospection)DatabaseOperations)DatabaseSchemaEditor)Oracle_datetimedsn)DatabaseValidationc              c   s   y
d V  W np t jk
rz }  zR| jd }t|drht|drh|jdkrhd|jksZd|jkrhtt| j  W Y d d } ~ X nX d S )Nr   codemessagei+  z	ORA-02291z	ORA-00001)DatabaseDatabaseErrorargshasattrr*   r+   r   tuple)r   xr   r   r   wrap_oracle_errors?   s    




r2   c               @   s   e Zd ZdddZdS )!_UninitializedOperatorsDescriptorNc             C   s&   |d krt d|j j  |jd S )Nz*operators not available as class attribute	operators)AttributeErrorcursorclose__dict__)selfinstanceclsr   r   r   __get__[   s    z)_UninitializedOperatorsDescriptor.__get__)N)__name__
__module____qualname__r<   r   r   r   r   r3   Y   s   r3   c                   sz  e Zd ZdZdZddddddd	d
ddddddddddddddddddd	dddZdddddddZdMZe Z	dddd d!d"d#d$ddd d d%Z
e
d&d'd&d&d'd'd(Zd)Zd*d+d,d-d.d/d0Zd1d2 ej D Zd3d2 ej D ZeZeZeZeZeZeZeZeZ fd4d5Z d6d7 Z!e"d8d9 Z#d:d; Z$e"dNd=d>Z%d?d@ Z&dAdB Z'dCdD Z(dOdEdFZ)dGdH Z*e+dIdJ Z,e+dKdL Z-  Z.S )PDatabaseWrapperoracleZOraclez3NUMBER(11) GENERATED BY DEFAULT ON NULL AS IDENTITYz3NUMBER(19) GENERATED BY DEFAULT ON NULL AS IDENTITYZBLOBz	NUMBER(1)zNVARCHAR2(%(max_length)s)ZDATE	TIMESTAMPz*NUMBER(%(max_digits)s, %(decimal_places)s)zINTERVAL DAY(9) TO SECOND(6)zDOUBLE PRECISIONz
NUMBER(11)ZNCLOBz
NUMBER(19)zVARCHAR2(15)zVARCHAR2(39)z2NUMBER(5) GENERATED BY DEFAULT ON NULL AS IDENTITYzVARCHAR2(%(max_length)s)zVARCHAR2(32))Z	AutoFieldZBigAutoFieldZBinaryFieldBooleanFieldZ	CharFieldZ	DateFieldZDateTimeFieldZDecimalFieldZDurationFieldZ	FileFieldZFilePathFieldZ
FloatFieldZIntegerField	JSONFieldZBigIntegerFieldZIPAddressFieldZGenericIPAddressFieldNullBooleanFieldZOneToOneFieldPositiveBigIntegerFieldPositiveIntegerFieldPositiveSmallIntegerFieldZ	SlugFieldZSmallAutoFieldZSmallIntegerFieldZ	TextFieldZ	TimeFieldZURLFieldZ	UUIDFieldz%(qn_column)s IN (0,1)z%(qn_column)s IS JSONz%(qn_column)s >= 0)rC   rD   rE   rF   rG   rH   clobnclobblobz= %sz= UPPER(%s)zFLIKE TRANSLATE(%s USING NCHAR_CS) ESCAPE TRANSLATE('\' USING NCHAR_CS)zMLIKE UPPER(TRANSLATE(%s USING NCHAR_CS)) ESCAPE TRANSLATE('\' USING NCHAR_CS)z> %sz>= %sz< %sz<= %s)exactZiexactcontains	icontainsgtZgteltZlter   endswithistartswith	iendswithzLIKEC %s ESCAPE '\'zLIKEC UPPER(%s) ESCAPE '\')rM   rN   r   rQ   rR   rS   z@REPLACE(REPLACE(REPLACE({}, '\', '\\'), '%%', '\%%'), '_', '\_')z'%%' || {} || '%%'z'%%' || UPPER({}) || '%%'z
{} || '%%'zUPPER({}) || '%%'z
'%%' || {}z'%%' || UPPER({}))rM   rN   r   rR   rQ   rS   c             C   s   i | ]\}}d | d |qS )zLIKE TRANSLATE( z5 USING NCHAR_CS) ESCAPE TRANSLATE('\' USING NCHAR_CS)r   ).0kvr   r   r   
<dictcomp>   s   zDatabaseWrapper.<dictcomp>c             C   s   i | ]\}}d | d |qS )zLIKEC z ESCAPE '\'r   )rT   rU   rV   r   r   r   rW      s   c                s,   t  j|| | jd jdd}|| j_d S )NOPTIONSuse_returning_intoT)super__init__settings_dictgetfeaturesZcan_return_columns_from_insert)r9   r.   kwargsrY   )	__class__r   r   r[      s    zDatabaseWrapper.__init__c             C   s    | j d j }d|kr|d= |S )NrX   rY   )r\   copy)r9   conn_paramsr   r   r   get_connection_params   s    z%DatabaseWrapper.get_connection_paramsc             C   s*   t jf | jd | jd t| jd|S )NUSERZPASSWORD)userpasswordr(   )r,   connectr\   r(   )r9   rb   r   r   r   get_new_connection   s
    z"DatabaseWrapper.get_new_connectionc             C   s   | j  }|jd |jdtjr"dnd  |j  d| jkr| j  }y|jd| jd  dg W n& tjk
r   | j	| _
| j| _Y nX | j| _
| j| _|j  d	| j_| j s| j  d S )
Nz+ALTER SESSION SET NLS_TERRITORY = 'AMERICA'zmALTER SESSION SET NLS_DATE_FORMAT = 'YYYY-MM-DD HH24:MI:SS' NLS_TIMESTAMP_FORMAT = 'YYYY-MM-DD HH24:MI:SS.FF'z TIME_ZONE = 'UTC' r4   z!SELECT 1 FROM DUAL WHERE DUMMY %srM   X   )create_cursorexecuter   USE_TZr7   r8   _standard_operatorsr,   r-   _likec_operatorsr4   _likec_pattern_opsZpattern_ops_standard_pattern_ops
connectionZstmtcachesizeZget_autocommitcommit)r9   r6   r   r   r   init_connection_state   s*    


z%DatabaseWrapper.init_connection_stateNc             C   s
   t | jS )N)FormatStylePlaceholderCursorrs   )r9   r   r   r   r   rl     s    zDatabaseWrapper.create_cursorc          	   C   s&   | j d k	r"t  | j j S Q R X d S )N)rs   r2   rt   )r9   r   r   r   _commit  s    
zDatabaseWrapper._commitc             C   s(   | j r$| jjd| jj| dd d S )Nz-- RELEASE SAVEPOINT %s (faked)z0.000)Zsqltime)Zqueries_loggedZqueries_logappendopsZ
quote_name)r9   Zsidr   r   r   _savepoint_commit  s    z!DatabaseWrapper._savepoint_commitc          	   C   s   | j  || j_W d Q R X d S )N)Zwrap_database_errorsrs   
autocommit)r9   r|   r   r   r   _set_autocommit&  s    zDatabaseWrapper._set_autocommitc          	   C   s,   | j  }|jd |jd W dQ R X dS )zl
        Check constraints by setting them to immediate. Return them to deferred
        afterward.
        zSET CONSTRAINTS ALL IMMEDIATEzSET CONSTRAINTS ALL DEFERREDN)r6   rm   )r9   Ztable_namesr6   r   r   r   check_constraints*  s    

z!DatabaseWrapper.check_constraintsc             C   s.   y| j j  W n tjk
r$   dS X dS d S )NFT)rs   Zpingr,   Error)r9   r   r   r   	is_usable3  s
    zDatabaseWrapper.is_usablec             C   s   t dd tjjdD S )Nc             s   s   | ]}t |V  qd S )N)int)rT   r1   r   r   r   	<genexpr>=  s    z4DatabaseWrapper.cx_oracle_version.<locals>.<genexpr>.)r0   r,   versionsplit)r9   r   r   r   cx_oracle_version;  s    z!DatabaseWrapper.cx_oracle_versionc             C   s0   | j   tdd | jjjdD S Q R X d S )Nc             s   s   | ]}t |V  qd S )N)r   )rT   r1   r   r   r   r   B  s    z1DatabaseWrapper.oracle_version.<locals>.<genexpr>r   )Ztemporary_connectionr0   rs   r   r   )r9   r   r   r   oracle_version?  s    
zDatabaseWrapper.oracle_version)rI   rJ   rK   )N)N)/r=   r>   r?   vendorZdisplay_nameZ
data_typesZdata_type_check_constraintsZ_limited_data_typesr3   r4   ro   rp   Zpattern_escZ_pattern_opsitemsrr   rq   r,   r&   ZSchemaEditorClassr!   Zclient_classr"   Zcreation_classr#   Zfeatures_classr$   Zintrospection_classr%   Z	ops_classr)   Zvalidation_classr[   rc   r   rh   ru   rl   rw   r{   r}   r~   r   r
   r   r   __classcell__r   r   )r`   r   r@   f   s   	
	(
	r@   c               @   s   e Zd ZdZdddZdS )OracleParama  
    Wrapper object for formatting parameters for Oracle. If the string
    representation of the value is large enough (greater than 4000 characters)
    the input size needs to be set as CLOB. Alternatively, if the parameter
    has an `input_size` attribute, then the value of the `input_size` attribute
    will be used instead. Otherwise, no input size will be set for the
    parameter when executing the query.
    Fc             C   s   t jr(t|tjr(t|t r(tj|}d}|dkr:d}n|dkrFd}t|dr^|j|| _nHt|t	j
tjfrx|| _n.t||j|| _t| jtrtt||j|}t|dr|j| _n.|dkrt	j| _nt|tjrt	j| _nd | _d S )Nr   Tr    Fbind_parameter
input_sizei  )r   rn   
isinstancedatetimer'   from_datetimer/   r   r   r,   Binary	timedeltar	   charsetstrlenr   ZCLOBrB   )r9   paramr6   Zstrings_onlyZstring_sizer   r   r   r[   O  s,    





zOracleParam.__init__N)F)r=   r>   r?   __doc__r[   r   r   r   r   r   E  s   r   c               @   s0   e Zd ZdZdd Zdd Zdd Zdd	 Zd
S )VariableWrappera	  
    An adapter class for cursor variables that prevents the wrapped object
    from being converted into a string when used to instantiate an OracleParam.
    This can be used generally for any other object that should be passed into
    Cursor.execute as-is.
    c             C   s
   || _ d S )N)var)r9   r   r   r   r   r[   {  s    zVariableWrapper.__init__c             C   s   | j S )N)r   )r9   r6   r   r   r   r   ~  s    zVariableWrapper.bind_parameterc             C   s   t | j|S )N)getattrr   )r9   keyr   r   r   __getattr__  s    zVariableWrapper.__getattr__c             C   s&   |dkr|| j |< nt| j|| d S )Nr   )r8   setattrr   )r9   r   r   r   r   r   __setattr__  s    zVariableWrapper.__setattr__N)r=   r>   r?   r   r[   r   r   r   r   r   r   r   r   s  s
   r   c               @   s   e Zd ZdZdZdd Zedd Zedd Zed	d
 Z	dd Z
dd Zdd Zd#ddZd$ddZd%ddZdd Zdd Zdd Zdd  Zd!d" ZdS )&rv   z
    Django uses "format" (e.g. '%s') style placeholders, but Oracle uses ":var"
    style. This fixes it -- but note that if you want to use a literal "%s" in
    a query, you'll need to use "%%s".
    zutf-8c             C   s   |j  | _ | j| j _d S )N)r6   _output_type_handlerZoutputtypehandler)r9   rs   r   r   r   r[     s    
z%FormatStylePlaceholderCursor.__init__c             C   s   d| krt j| S t| S )Nr   )decimalDecimalr   )r   r   r   r   _output_number_converter  s    z5FormatStylePlaceholderCursor._output_number_converterc                s8   |dkrt S tj| d tjdj|  fddS )Nr   )precr    c                s   t j| j dS )N)context)r   r   quantize)rV   )r   quantize_valuer   r   <lambda>  s    zEFormatStylePlaceholderCursor._get_decimal_converter.<locals>.<lambda>)r   r   Contextr   scaleb)	precisionscaler   )r   r   r   _get_decimal_converter  s
    z3FormatStylePlaceholderCursor._get_decimal_converterc             C   s^   |t jkrZ|dkr(|dkr"tj}qDt}n|dkr>tj||}ntj}| jt jd| j|dS dS )zx
        Called for each db column fetched from cursors. Return numbers as the
        appropriate Python type.
           r      )size	arraysizeoutconverterNi)	r,   NUMBERrv   r   floatr   r   STRINGr   )r6   r   ZdefaultTypelengthr   r   r   r   r   r   r     s    
z1FormatStylePlaceholderCursor._output_type_handlerc                sB   y fdd|j  D S  tk
r<   t fdd|D S X d S )Nc                s   i | ]\}}t | d |qS )T)r   )rT   rU   rV   )r9   r   r   rW     s    z?FormatStylePlaceholderCursor._format_params.<locals>.<dictcomp>c             3   s   | ]}t | d V  qdS )TN)r   )rT   p)r9   r   r   r     s    z>FormatStylePlaceholderCursor._format_params.<locals>.<genexpr>)r   r5   r0   )r9   paramsr   )r9   r   _format_params  s    z+FormatStylePlaceholderCursor._format_paramsc             C   s   t |d drXi }x2|D ]*}x$|j D ]\}}|jr&|j||< q&W qW |r| jf | nTd gt|d  }x2|D ]*}x$t|D ]\}}|jr~|j||< q~W qpW |r| j|  d S )Nr   keys)r/   r   r   Zsetinputsizesr   	enumerate)r9   Zparams_listsizesr   rU   r   ir   r   r   _guess_input_sizes  s    

z/FormatStylePlaceholderCursor._guess_input_sizesc             C   s.   t |drdd |j D S dd |D S d S )Nr   c             S   s   i | ]\}}|j |qS r   )r   )rT   rU   rV   r   r   r   rW     s    zAFormatStylePlaceholderCursor._param_generator.<locals>.<dictcomp>c             S   s   g | ]
}|j qS r   )r   )rT   r   r   r   r   
<listcomp>  s    zAFormatStylePlaceholderCursor._param_generator.<locals>.<listcomp>)r/   r   )r9   r   r   r   r   _param_generator  s    
z-FormatStylePlaceholderCursor._param_generatorFc                s   |j ds|j dr |d d }|d kr.g }nt|drPdd |D }|| }nt|r|rdd ttj|D   fdd	|D }d
d  j D }|t| }n"dd	 tt|D }|t| }|| j	|fS )N;/r    r   c             S   s   i | ]}d | |qS )z:%sr   )rT   rU   r   r   r   rW     s    z@FormatStylePlaceholderCursor._fix_for_params.<locals>.<dictcomp>c             S   s   i | ]\}}d | |qS )z:arg%dr   )rT   r   r   r   r   r   rW     s   c                s   g | ]} | qS r   r   )rT   r   )params_dictr   r   r     s    z@FormatStylePlaceholderCursor._fix_for_params.<locals>.<listcomp>c             S   s   i | ]\}}||qS r   r   )rT   r   r   r   r   r   rW     s    c             S   s   g | ]}d | qS )z:arg%dr   )rT   r   r   r   r   r     s    )
rQ   r/   r   dictfromkeysr   r0   ranger   r   )r9   queryr   unify_by_valuesr.   r   )r   r   _fix_for_params  s     

z,FormatStylePlaceholderCursor._fix_for_paramsNc             C   sF   | j ||dd\}}| j|g t  | jj|| j|S Q R X d S )NT)r   )r   r   r2   r6   rm   r   )r9   r   r   r   r   r   rm     s    z$FormatStylePlaceholderCursor.executec                st   |sd S t |} j|t|\}}|g fdd|D  } j| t   jj| fdd|D S Q R X d S )Nc                s   g | ]} j |qS r   )r   )rT   r   )r9   r   r   r     s    z<FormatStylePlaceholderCursor.executemany.<locals>.<listcomp>c                s   g | ]} j |qS r   )r   )rT   r   )r9   r   r   r     s    )iterr   nextr   r2   r6   executemany)r9   r   r   Zparams_iterZfirstparams	formattedr   )r9   r   r     s    
z(FormatStylePlaceholderCursor.executemanyc             C   s*   y| j j  W n tjk
r$   Y nX d S )N)r6   r7   r,   ZInterfaceError)r9   r   r   r   r7     s    z"FormatStylePlaceholderCursor.closec             G   s   t | jj| S )N)r   r6   r   )r9   r.   r   r   r   r   "  s    z FormatStylePlaceholderCursor.varc             G   s   t | jj| S )N)r   r6   arrayvar)r9   r.   r   r   r   r   %  s    z%FormatStylePlaceholderCursor.arrayvarc             C   s   t | j|S )N)r   r6   )r9   attrr   r   r   r   (  s    z(FormatStylePlaceholderCursor.__getattr__c             C   s
   t | jS )N)r   r6   )r9   r   r   r   __iter__+  s    z%FormatStylePlaceholderCursor.__iter__)F)N)N)r=   r>   r?   r   r   r[   staticmethodr   r   r   r   r   r   r   rm   r   r7   r   r   r   r   r   r   r   r   rv     s"   !
"

rv   )r   r   )r   r   )2r   r   r   r   r   
contextlibr   Zdjango.confr   Zdjango.core.exceptionsr   Z	django.dbr   Zdjango.db.backends.base.baser   Zdjango.utils.asyncior   Zdjango.utils.encodingr   r	   Zdjango.utils.functionalr
   r   Z	cx_Oracler,   r   r   clientr!   Zcreationr"   r^   r#   Zintrospectionr$   
operationsr%   Zschemar&   utilsr'   r(   Z
validationr)   r2   r3   r@   r   r   rv   r   r   r   r   <module>   sF    `.